• 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("
    ");
        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
    */
  • 相关阅读:
    jQuery琐碎
    jQuery文档加载事件
    微信,禁止分享页面
    级联下拉列表
    struts2 result随笔
    C++知识点(四)类与对象,结构体、联合体、枚举类
    C++知识点(三)函数
    剑指offer-二叉树
    LeetCode:Remove Element
    LeetCode:Remove Duplicates from Sorted Array
  • 原文地址:https://www.cnblogs.com/dreamhome/p/8635638.html
Copyright © 2020-2023  润新知