在很多场景中,我们的服务器都需要跟用户的浏览器打交道,如表单提交。
表单提交到服务器一般都使用 GET/POST 请求。
URL模块
- 将一个url字符串解析并返回一个url对象
url.parse(urlstr[,parseQueryString[,slashesDenoteHost]])
参数解析:
-
urlstr --> 需要解析的url字符串
-
parseQueryString --> 布尔值:(默认为false) 若采用url传输,必须将这个参数设置为true,才能将
url参数(?前的地址和?后的参数)
解析出来 -
slashesDenoteHost -->布尔值:(默认为false) 为true表示://之后和下一格/之前的第一个标记被解释为主机
-
将url对象编程一个url字符串
url.format(obj)
-
将from ,to 拼接
url.resolve(from,to)
HTTP模块
1.get工作过程:
- 使用
url模块
parse方法将客户请求路径中的文件名找出来 - 使用
fs模块
readfile方法将文件读出来 - 发送响应信息,并断开连接(response)
实例:
获取get请求内容:
由于GET请求直接被嵌入在路径中,URL是完整的请求路径,包括了?后面的部分,因此可以手动解析后面的内容作为GET请求的参数。
\node.js 中 url 模块中的 parse 函数提供了这个功能。
var http = require('http');
var url = require('url');
var util = require('util');
http.createServer(function(req, res){
res.writeHead(200, {
'Content-Type': 'text/plain; charset=utf-8'});
res.end(util.inspect(url.parse(req.url, true)));
}).listen(3000);
获取url的参数:
var http = require('http');
var url = require('url');
var util = require('util');
http.createServer(function(req, res){
res.writeHead(200, {
'Content-Type': 'text/plain'});
// 解析 url 参数
var params = url.parse(req.url, true).query;
res.write("网站名:" + params.name);
res.write("\n");
res.write("网站 URL:" + params.url);
res.end();
}).listen(3000);
2. post工作过程
- 给request对象的
‘data’
事件绑定一个函数,触发时将读到页面文件 - 给request对象的
‘end’
事件绑定一个函数,触发时表示文件已读取,可用querystring模块
提取body标签下的内容 - 通过标签控件的
name属性名
获取相关控件的值
实例:
获取post请求的内容:
POST 请求的内容全部的都在请求体中,http.ServerRequest 并没有一个属性内容为请求体,原因是等待请求体传输可能是一件耗时的工作。
比如上传文件,而很多时候我们可能并不需要理会请求体的内容,恶意的POST请求会大大消耗服务器的资源,所以 node.js 默认是不会解析请求体的,当你需要的时候,需要手动来做。
var http = require('http');
var querystring = require('querystring');
var util = require('util');
http.createServer(function(req, res){
// 定义了一个post变量,用于暂存请求体的信息
var post = '';
// 通过req的data事件监听函数,每当接受到请求体的数据,就累加到post变量中
req.on('data', function(chunk){
post += chunk;
});
// 在end事件触发后,通过querystring.parse将post解析为真正的POST请求格式,然后向客户端返回。
req.on('end', function(){
post = querystring.parse(post);
res.end(util.inspect(post));
});
}).listen(3000);