Node js GET POST请求

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

node.js 中 url 模块中的 parse 函数提供了这个功能。
例
*/
//===============================以下代码为main.js文件中内容==========================================

var http = require('http');
var url = require('url');
var util = require('util');
 
http.createServer(function(request, response){
    response.writeHead(200, {'Content-Type': 'text/plain; charset=utf-8'});
 
    // 解析 url 参数
    var params = url.parse(request.url, true).query;
    response.write("name:" + params.name);
    response.write("\n");
    response.write("url:" + params.url);

    //util.inspect()像浏览器页面输出内容
    //response.end(util.inspect(url.parse(request.url, true)));
    response.end();
 
}).listen(8888);

//===============================以上代码为main.js文件中内容==========================================
/*
执行main.js
node main.js
浏览器输入:
http://127.0.0.1:8888/?name=testname&url=localhost
浏览器输出内容:
name:testname
url:localhost
*/











/*
POST 请求的内容全部的都在请求体中,http.ServerRequest 并没有一个属性内容为请求体,原因是等待请求体传输可能是一件耗时的工作。

比如上传文件,而很多时候可能并不需要理会请求体的内容,恶意的POST请求会大大消耗服务器的资源,所以 node.js 默认是不会解析请求体的,当需要的时候,需要手动来做。
例
*/
//===============================以下代码为main.js文件中内容==========================================

var http = require('http');
var querystring = require('querystring');

var postHTML =
    '<html><head><meta charset="utf-8"><title>nodejs POST测试</title></head>' +
    '<body>' +
    '<form method="post" action="">' +
    '网站名: <input name="name"><br>' +
    '网站 URL: <input name="url"><br>' +
    '<input type="submit">' +
    '</form>' +
    '</body></html>';

http.createServer(function (request, response) {
    // 定义了一个body变量,用于暂存请求体的信息
    var body = "";
    // 通过request的data事件监听函数,每当接受到请求体的数据,就累加到post变量中
    request.on('data', function (chunk) {
        body += chunk;
    });
    // 在end事件触发后,通过querystring.parse将post解析为真正的POST请求格式,然后向客户端返回。
    request.on('end', function () {
        // 解析参数
        body = querystring.parse(body);
        // 设置响应头部信息及编码
        response.writeHead(200, {'Content-Type': 'text/html; charset=utf8'});

        // 如果有提交数据输出提交的数据
        if(body.name && body.url) {
            response.write("网站名:" + body.name);
            response.write("<br>");
            response.write("网站 URL:" + body.url);
        // 否则输出表单
        } else {
            response.write(postHTML);
        }
        response.end();
    });
}).listen(8888);

//===============================以上代码为main.js文件中内容==========================================
/*
执行main.js
node main.js
浏览器输入:
http://127.0.0.1:8888/
填写表单网站名和网站URL点提交
浏览器输出提交的网站名和URL
*/

 

posted @ 2018-03-23 23:25  风吹屁股凉冰冰  阅读(180)  评论(0编辑  收藏  举报