一、获取http请求的报文语法总结
要想获取请求数据,需要通过request对象
(1)获取请求方法 request.method
(2)获取请求版本 request.httpVersion
(3)获取路径 request.url
(4)获取url路径 request('url').parse(request.url).pathname
(5)获取url查询字符串 request.('url').parse(request.url,true).query
(6)获取请求头 request.headers
(7)获取请求体 request.on('data',function(chunk){}) <br/> request.on('end',function(){}); 声明一个变量data,绑定data事件与end事件,最后添加响应
注意:
(1)request.url只能获取路径以及查询字符串,无法获取url中的域名以及协议内容
(2)favicon.ico 是属于浏览器自动发送的请求
二、代码示例:
(1)获取请求、请求的url、http协议的版本号、http请求头、http请求体
// 1.导入http模块
const http=require('http');
// 2.创建服务对象
const server=http.createServer((request,response)=>{
response.end('hello,world!'); //设置响应体
// 获取请求的方法:
console.log(request.method); //GET GET 我们浏览器有两个名称项目,所以发了两次get请求
// 获取请求的url:
// 它只包含url中的路径与查询字符串
console.log(request.url); // /search?keyword=5&num=1 /favicon.ico
// 获取http协议的版本号:
console.log(request.httpVersion); //1.1 1.1
// 获取http的请求头:
console.log(request.headers); //结果是一个对象,对象里面包含了请求头的所有内容
// 获取其中一个请求头例如host,我们可以console.log(request.headers.host);
// 获取http的请求体内容:***
// (1)声明一个变量
let body='';
// (2)绑定data事件
request.on('data',chunk=>{
body+=chunk;
});
// (3)绑定end事件
request.on('end',()=>{
console.log(body);
// 添加响应:
response.end('Hello HTTP!');
}); //回车后控制台结果为空,因为我们发送的是一个get请求。
// 解决办法:借助于上文我们那个html里面写的那个提交的表单来发送一个post请求
//提交后发送请求,控制台结果为我们填写的请求体内容:username=111&password=111
});
// 3.监听端口,启动服务
server.listen(9000,()=>{
console.log('服务已经启动...');
});
//注意启动谷歌端口时输入http://127.0.0.1:9000/search?keyword=111; 才能查询到url路径为search字符串为111
(2)获取http请求报文中的请求路径与查询字符串:
虽然request.url已包含属性和查询字符串,但使用不便,若只需其中一个不好提取,于是用到了如下路径和字符串的单独查询方法:
方法一:
const http=require('http');
// 一、获取路径:
// 1.导入url模块
const url=require('url');
const server=http.createServer((request,response)=>{
response.end('url');
// 2.解析request.url
console.log(request.url); //虽然request.url已包含属性和查询字符串 /search?keyword=5&num=1 /favicon.ico 但使用不便,若只需其中一个不好提取,于是用到了如下路径和字符串的单独查询方法
let res=url.parse(request.url,true); //使用parse去解析request.url里的内容
console.log(res); //输出可以看到 路径为pathname: '/search', pathname: '/favicon.ico', 后接true,使查询字符串变成了一个对象
let pathname=res.pathname;
console.log(pathname); // /search /favicon.ico 可以看到pathname里就是我们所要的路径
// 二、获取查询字符串:
let keyword=res.query.keyword;
console.log(keyword); //5 undefined 第一个url的keyword为5,第二个url里面没有包含keyword这个参数所以为undefined
});
server.listen(9000,()=>{
console.log('服务已启动...');
});
//注意启动谷歌端口时输入http://127.0.0.1:9000/search?keyword=111; 才能查询到url路径为search字符串为111
方法二:
const http=require('http');
const server=http.createServer((request,response)=>{
response.end('url new');
// 一、获取路径:
// (1)实例化一个URL对象 必须由域名或ip、路径与字符串组成
let url=new URL('http://www.xxx.com/search?a=100&b=200'); //或者new URL('http://127.0.0.1:9000','search?a=100&b=200')
let url=new URL(request.url,'http://www.xxx.com/search?'); //或者new URL('http://127.0.0.1:9000','search?a=100&b=200')
console.log(url);
// 输出路径
console.log(url.pathname); // /search /favicon.ico
// 二、查询字符串:
// 输出keyword查询字符串
// 如下search属性里是一个字符串形式的查询字符串,有点不方便。所以我们使用searchParams这个对象里面的keyword属性
console.log(url.searchParams.get('keyword')); // /search 5 /favicon.ico null
});
server.listen(9000,()=>{
console.log('服务已启动...');
});
//注意启动谷歌端口时输入http://127.0.0.1:9000/search?keyword=111; 才能查询到url路径为search字符串为111