Node-GET请求和POST请求的用法

题记

get请求和post请求的用法,以下是具体操作和代码。

表单提交到服务器一般都使用 GET和POST 请求。

获取GET请求内容

GET请求直接被嵌入在路径中,URL是完整的请求路径,包括了?后面的部分,可以手动解析后面的内容作为GET请求的参数。

node.js 中 url 模块中的 parse 函数可以解析?后面的内容作为GET请求的参数。

实例:

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);

javascript 复制代码
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);

在浏览器中访问:

http://localhost:3000/user?name=ngxe\&url=www.ngxe.com

获取URL的参数

使用 url.parse 方法来解析 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);

javascript 复制代码
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);

在浏览器中访问:

http://localhost:3000/user?name=ngxe\&url=www.ngxe.com

获取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);

javascript 复制代码
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);

实例:

var http = require('http');

var querystring = require('querystring');

var postHTML =

'<html><head><meta charset="utf-8"><title>实例</title></head>' +

'<body>' +

'<form method="post">' +

'网站名: <input name="name"><br>' +

'网站 URL: <input name="url"><br>' +

'<input type="submit">' +

'</form>' +

'</body></html>

javascript 复制代码
var http = require('http');
var querystring = require('querystring');
 
var postHTML = 
  '<html><head><meta charset="utf-8"><title>实例</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) {
  var body = "";
  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);

后记

觉得有用可以点赞或收藏!

相关推荐
詩句☾⋆᭄南笙几秒前
HTML列表、表格和表单
服务器·前端·html·表格·列表·表单
IT_陈寒13 分钟前
Python性能翻倍的5个冷门技巧:从GIL逃逸到内存视图的实战优化指南
前端·人工智能·后端
_extraordinary_13 分钟前
Java Spring配置
java·开发语言·spring
程序员爱钓鱼16 分钟前
Python编程实战 · 基础入门篇 | 第一个Python程序:Hello World
后端·python·编程语言
南城巷陌17 分钟前
错误边界:用componentDidCatch筑起React崩溃防火墙
前端·react.js·前端框架
FinClip23 分钟前
OpenAI推出Apps SDK,你的企业App跟上了吗?
前端·app·openai
馨谙28 分钟前
Linux中的管道与重定向:深入理解两者的本质区别
前端·chrome
进击的大海贼32 分钟前
QT-C++ 自定义加工统计通用模块
开发语言·c++·qt
Rhys..33 分钟前
JS - npm init
开发语言·javascript·npm
夏天想36 分钟前
复制了一个vue的项目然后再这个基础上修改。可是通过npm run dev运行之前的老项目,发现运行的竟然是拷贝后的项目。为什么会这样?
前端·vue.js·npm