Node.js GET/POST请求

本文详细介绍了在Node.js中如何处理HTTP请求,特别是GET和POST请求。对于GET请求,可以通过url模块的parse函数获取URL参数;对于POST请求,需要监听data和end事件来累积并解析请求体内容。示例代码展示了如何接收和显示表单提交的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在很多场景中,我们的服务器都需要跟用户的浏览器打交道,如表单提交。

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

本章节我们将为大家介绍 Node.js GET/POST请求。

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

在浏览器中访问 http://localhost:3000/user?name=菜鸟教程&url=www.runoob.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);

在浏览器中访问 http://localhost:3000/user?name=菜鸟教程&url=www.runoob.com 然后查看返回结果:

完整实例:

const http = require("http");
const url = require("url");
const util = require("util");

http.createServer((req, res) => {
    const _url = req.url;
    console.log("====================");
    console.log(_url); // /user?name=%E8%8F%9C%E9%B8%9F%E6%95%99%E7%A8%8B&url=www.runoob.com
    console.log("====================");
    const params = url.parse(_url, true).query;
    console.log(util.inspect(params));

    const param1 = {
        name: 'Tom',
        day: 'Monday'
    }

    console.log(JSON.stringify(param1));
    console.log(util.inspect(param1));

    const param2 = {
        size: "large",
        get: function(){
            return this.size;
        }
    }

    console.log(typeof JSON.stringify(param2));
    console.log(typeof util.inspect(param2));

    res.writeHead(200, {"Content-Type": "text/plain; charset=utf-8"});
    res.end("name: " + params.name + ", url: " + params.url)
}).listen(9999, () => {
    console.log("服务启动成功!");
})

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

以下实例表单通过 POST 提交并输出数据:

实例

var http = require('http');
var querystring = require('querystring');
 
var postHTML = 
  '<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>

执行结果 Gif 演示:

 完整实例:

var http = require('http');
var querystring = require('querystring');
 
var postHTML = 
  '<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) {
  var body = "";
  req.on('data', function (chunk) {
    console.log(chunk.toString());
    body += chunk.toString();
  });
  req.on('end', function () {
    // 解析参数
    console.log("====================");
    console.log(typeof body);
    console.log(body); // name=%E4%B8%AD%E5%9B%BD&url=www.gov.com.cn
    console.log("====================");
    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(5555);

 

### 华为路由器AR系列端口映射配置方法 对于华为AR系列路由器,当需要进行端口映射时,可以通过命令行接口(CLI)来实现更灵活的操作。由于Web界面存在一定的局限性,在处理复杂或多端口映射需求时推荐使用CLI方式进行配置。 #### 基本概念说明 端口映射是指将外部网络请求转发至内部特定服务器的过程。通过这种方式可以让位于私有网络中的设备能够被公网访问。在华为AR系列路由器中,主要涉及NAT(Network Address Translation)功能的应用。 #### CLI环境下的多端口映射实例 针对连续范围内的TCP端口号进行映射操作如下所示: ```shell [Huawei-GigabitEthernet0/0/1] nat static protocol tcp global current-interface 11000 14000 inside 192.168.1.1 11000 14000 ``` 上述指令实现了对外部接口上的`current-interface` IP地址从11000到14000之间的所有入站连接重定向给内网主机`192.168.1.1`相同区间段的监听服务[^3]。 #### 单一端口映射示例 如果只需要开放单一端口,则可采用更为简洁的方式完成设置: ```shell [Huawei-GigabitEthernet0/0/1] nat server protocol tcp global current-interface 1433 inside 192.168.1.200 1433 ``` 这条语句的作用是把来自外网对当前接口IP地址发起的目标端口为1433的数据包转交给局域网内的计算机(`192.168.1.200`)同样编号的服务程序去响应[^5]。 #### 注意事项 - 执行任何更改之前建议先备份现有配置文件以防意外情况发生。 - 使用`dir`命令可以浏览存储介质上的文件列表;而要清除先前保存过的启动参数则需调用`reset saved-configuration`;最后执行`reboot`使新的设定生效[^4].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值