Node.js GET/POST请求
在很多场景中,我们的服务器都需要跟用户的浏览器打交道,如表单提交。
表单提交到服务器一般都使用 GET/POST 请求。
本章节我们将为大家介绍 Node.js GET/POS T请求。
获取GET请求内容
由于GET请求直接被嵌入在路径中,URL是完整的请求路径,包括了?后面的部分,因此你可以手动解析后面的内容作为GET请求的参数。
node.js 中 url 模块中的 parse 函数提供了这个功能。
实例
varhttp
=require('http');varurl
=require('url');varutil
=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);
在浏览器中访问 http://localhost:3000/user?name=菜鸟教程&url=www.runoob.com 然后查看返回结果:
获取 URL 的参数
我们可以使用 url.parse 方法来解析 URL 中的参数,代码如下:
实例
varhttp
=require('http');varurl
=require('url');varutil
=require('util');http.createServer(function(req,res){res.writeHead(200,{'Content-Type':'text/plain'});//
解析 url 参数varparams
=url.parse(req.url,true).query;res.write("网站名:"
+ params.name);res.write("\n");res.write("网站
URL:" +params.url);res.end();}).listen(3000);
在浏览器中访问 http://localhost:3000/user?name=菜鸟教程&url=www.runoob.com 然后查看返回结果:
获取 POST 请求内容
POST 请求的内容全部的都在请求体中,http.ServerRequest 并没有一个属性内容为请求体,原因是等待请求体传输可能是一件耗时的工作。
比如上传文件,而很多时候我们可能并不需要理会请求体的内容,恶意的POST请求会大大消耗服务器的资源,所以 node.js 默认是不会解析请求体的,当你需要的时候,需要手动来做。
基本语法结构说明
varhttp
=require('http');varquerystring
=require('querystring');http.createServer(function(req,res){//
定义了一个post变量,用于暂存请求体的信息varpost
='';//
通过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);
以下实例表单通过 POST 提交并输出数据:
实例
varhttp
=require('http');varquerystring
=require('querystring');varpostHTML
='<html><head><meta charset="utf-8"><title>菜鸟教程 Node.js 实例</title></head>'
+ '<body>'
+ '<form method="post">'
+ '网站名: <input name="name"><br>'
+ '网站 URL: <input name="url"><br>'
+ '<input type="submit">'
+ '</form>'
+ '</body></html>';http.createServer(function(req,res){varbody
="";req.on('data',function(chunk){body
+=chunk;});req.on('end',function(){//
解析参数body
=querystring.parse(body);//
设置响应头部信息及编码res.writeHead(200,{'Content-Type':'text/html;
charset=utf8'});if(body.name
&& body.url){//
输出提交的数据res.write("网站名:"
+ body.name);res.write("<br>");res.write("网站
URL:" +body.url);}else{//
输出表单res.write(postHTML);}res.end();});}).listen(3000);
执行结果 Gif 演示: