请求数据
前台:form、ajax、jsonp
后台:接受请求并返回响应数据
 
 
前台《= http协议 =》后台
 
常用的请求的方式:
1、GET           数据在url中
2、POST         数据不再url中
 
get方式:通过地址栏来传输     name=value&name1=value1&               作用:分享
 
post方式:通过head头传输      数据相对安全
 
form
 
     action="http://www.vaidu.com"          地址
     method:"post/get"                              传输方式
 
 
window.location.pathname         路径  也可以做跳转               www.baidu.com
window.location.port                  端口号                                   8080
window.location.hash                  锚点                                   #后面的
window.location.protocol           协议                                     http/https
window.location.search               数据                                   ?号后面的   name=value&name1=value1
 
浏览器 《=   通信数据   =》 服务器
 
通信数据:
1、头(header)
2、请求主体(content)
 
 
【GET方式】
<form action="http://localhost:8080/" method="get">
用户:<input type="text" name="user" value="" /><br>
密码:<imput type="password" name="pass" value="" /><br>
<input type="submit" value="提交">
</form>
const http = require('http');

http.createServer( (req,res) => {
console.log(req.url); // /aaa?user=jason&pass=123456
let GET = {};
let url = req.url;
// 判断请求的url中是否含有查询参数
if(url.indexOf('?') != -) {
let arr = url.split('?');
// arr[0] = 地址 '/aaa' arr[1] = 数据 'user=jason&pass=123456'
let arr2 = arr[].split('&');
for(let i = ; i < arr2.length; i++) {
let arr3 = arr2[i].split('=');
// arr3[0] ==>姓名 arr3[1] ==> 密码
GET[arr3[]] = arr3[];
}
}
res.write('有请求了');
res.end();
}).listen();
const http = require('http');

http.createServer( (req, res) => {
console.log(req.url);
let GET = {};
let url = req.url;
if(url.indexOf('?') != -) {
let arr = url.split('?');
url = arr[];
let arr2 = arr[].split('&');
for(let i = ; i < arr2.length; i++) {
let arr3 = arr2[i].split('=');
GET[arr3[]] = arr3[];
}
}
console.log(GET, url)
res.write('');
res.end();
}).listen();
 
提供querystring(查询字符) 模块
const querystring = require('querystring');
let GET = querystring.parse('name=jason&age=18');
console.log(GET); // { name: 'jason', password: '123456' } '/'
// {} '/favicon.ico'

url模块:

const urlLib = require('url');

let urlObj = urlLib.parse('http://www.baidu.com:8901/index/static?name=jason&age=18', true);

console.log(urlObj);

当第二个参数为true时:

Url {
protocol: 'http:',
slashes: true,
auth: null,
host: 'www.baidu.com:8901',
port: '',
hostname: 'www.baidu.com',
hash: null,
search: '?name=jason&age=18',
query: { name: 'jason', age: '' },
pathname: '/index/static',
path: '/index/static?name=jason&age=18',
href: 'http://www.baidu.com:8901/index/static?name=jason&age=18'
}

为false时:

Url {
protocol: 'http:',
slashes: true,
auth: null,
host: 'www.baidu.com:8901',
port: '',
hostname: 'www.baidu.com',
hash: null,
search: '?name=jason&age=18',
query: 'name=jason&age=18',
pathname: '/index/static',
path: '/index/static?name=jason&age=18',
href: 'http://www.baidu.com:8901/index/static?
name=jason&age='
}
区别为query是否被querystring
 
于是上面的例子可以被简写为
const http = require('http');
const urlLib = require('url'); http.createServer( (req, res) => {
let urlObj = urlLib.parse(req.url, true);
let GET = urlObj.query;
let urlName = urlObj.pathname;
console.log(GET, urlName);
res.write('完成');
res.end();
}).listen();
总结:
1.querystring模块只能解析     query
2.url可以解析整个url
 
【post请求】
请求头最大      32k
请求主体最大   1G
 
数据量的大小产生了数据处理方式的区别
 
处理很大的数据---分段处理  (防止堵塞和出错)
 
1.data事件   有一段数据到达的时候,可以发送很多次
req.on('data',  回调函数 function(data) {
     
});
2.end事件     数据全部到达的时候,只执行一次
     req.on('end', () => {
 
     });
<form action="http://localhost:8999/aaa" method="post">
账号:<input type="text" name="name" value=""><br>
密码:<input type="password" name="password" value=""><br>
<input type="submit" value="提交">
</form>
const http = require('http');
const querystring = require('querystring'); http.createServer( (req, res) => {
// post -- req
let str = '';
let i = ;
req.on('data', (data) => {
console.log(`第${i++}次接收到数据`);
str += data;
});
req.on('end', () => {
let POST = querystring.parse(str);
console.log(str);
});
}).listen();
得到的结果是:
 
第0次接收到数据
{
  name: 'jason',
  password: '123456',
}
const http = require('http');
const fs = require('fs');
const querystring = require('querystring');
const urlLib = require('url'); let server = http.createServer( (req, res) => {
// GET
let url = urlLib.parse(req.url).pathname;
const GET = urlLib.parse(req.url, true).query;
// POST
let str = '';
let POST;
req.on('data', (data) => {
str += data;
});
req.on('end', () => {
POST = querystring.parse(str);
console.log(url, GET, POST);
});
console.log(url, GET, POST);
// 文件读取
let file_name = './www' + url;
fs.readFile(file_name, (err, data) => {
if(err) {
res.write('');
}else{
res.write('读取成功');
}
res.end();
})
}); server.listen();
【get请求】
/aaa { name: 'jason ', password: '123456', text: 'abcd' } undefined
【post请求】
/aaa {} { name: 'jason ', password: '654321', text: 'zzzz' }
【文件读取】
/1.html {} {}
/favicon.ico {} undefined

nodejs学习笔记二(get请求、post请求、 querystring模块,url模块)的更多相关文章

  1. nodejs学习笔记二——链接mongodb

    a.安装mongoose库用来链接mongodb数据库 安装mongodb数据库参考mongodb安装 前言(怨言) 本来是想安装mongodb库来链接mongodb的,命令行到nodejs工程目录: ...

  2. nodejs学习笔记二:解析express框架项目文件

    上一章介绍了如何去创建一个express框架的工程项目,这章介绍一下express框架下的文件和用法解析,上一张我们创建的工程项目结构图如下: models是不属于原工程项目结构,为了实现数据模型后添 ...

  3. nodejs学习笔记<二>简单的node服务器

    在环境搭建好后,就可以开始动手架设(node驱动)一个简单的web服务器. 首先,nodejs还是用js编写.先来看一段node官网上的实例代码. var http = require('http') ...

  4. nodejs学习笔记<二> 使用node创建基础服务器

    创建服务器的 server.js 内容. var http = require("http"); // 引用http模块 http.createServer(function(re ...

  5. NodeJS学习笔记二

    类声明和类表达式 ES6 中的类实际上就是个函数,而且正如函数的定义方式有函数声明和函数表达式两种一样,类的定义方式也有两种,分别是:类声明.类表达式. 类声明 类声明是定义类的一种方式,就像下面这样 ...

  6. openresty 学习笔记二:获取请求数据

    openresty 学习笔记二:获取请求数据 openresty 获取POST或者GET的请求参数.这个是要用openresty 做接口必须要做的事情.这里分几种类型:GET,POST(urlenco ...

  7. Nodejs学习笔记(二)——Eclipse中运行调试Nodejs

    前篇<Nodejs学习笔记(一)——初识Nodejs>主要介绍了在搭建node环境过程中遇到的小问题以及搭建Eclipse开发Node环境的前提步骤.本篇主要介绍如何在Eclipse中运行 ...

  8. Nodejs学习笔记(六)--- Node.js + Express 构建网站预备知识

    目录 前言 新建express项目并自定义路由规则 如何提取页面中的公共部分? 如何提交表单并接收参数? GET 方式 POST 方式 如何字符串加密? 如何使用session? 如何使用cookie ...

  9. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

随机推荐

  1. swagger 在本地正常调试 发布后出现500 : {"Message":"出现错误。"}

    点击项目属性 勾上xml 解决

  2. [Java]java内存及数据区

    Java运行时的数据区包括:(其中前两个是线程共享的) 1.方法区(Method Area) 存储已被虚拟机加载的类信息.常量.静态变量.即时编译器编译后的代码等数据 2.堆(Heap) 存放对象实例 ...

  3. [多线程] Thread

    多线程 概述 单任务处理:一个任务完成后才能进行下一个任务. 多任务处理:CPU分时操作,每个任务看似同时运行. 进程 应用程序的一个运行实例,包含程序所需资源的内存区域,是操作系统进行资源分配的单元 ...

  4. RabbitMq初探——发布与订阅

    publish and subscribe 前言 前面的例子 我们都是用到的都是消息单一消费,即一条消息被单个消费者消费.像微博系统的消息推送,是一条消息推送给所有订阅到该频道的用户. 这里我们就需要 ...

  5. 关于布尔值bool值

    1.空或0布尔值为false,非0或非空为true 2.多个判断连在一起判断优先级:(括号)>not >and >or and:    print(27 and 1>4)  - ...

  6. 音频audio,加层父级

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. 洛谷P5292 [HNOI2019]校园旅行(二分图+最短路)

    题面 传送门 题解 如果暴力的话,我们可以把所有的二元组全都扔进一个队列里,然后每次往两边更新同色点,这样的话复杂度是\(O(m^2)\) 怎么优化呢? 对于一个同色联通块,如果它是一个二分图,我们只 ...

  8. python基础目录

    一.博客链接 1.基础操作 python基础,变量,if语句 while循环/格式化输出/ 逻辑运算/ 编码 /单位转换 列表的操作,元组,range; enumerate dict字典;dict的操 ...

  9. [Swift实际操作]八、实用进阶-(2)Swift语言中的三种消息传递模式

    本文将通过响应按钮的点击事件,来演示Target-Action消息传递机制,该机制主要用于响应用户的界面操作.打开创建的空白项目.然后在左侧的项目导航区,打开视图控制器的代码文件:ViewContro ...

  10. 使用unordered_map提升查找效率

    在对网络数据包流(Flow)进行处理的时候,一开始为了简单使用了vector做为Flow信息的存储容器,当其中的元素达到几十万时,程序的执行速度让人无法忍受.已经对vector进行过合理的预先rese ...