• [转] nodeJS的post提交简单实现


    index.js:

    1
    2
    3
    4
    5
    6
    7
    8
    var server = require('./server');
    var router = require('./route');
    var requestHandler = require('./requestHandler');
    var hander = {};
    hander['/'] = requestHandler.start;
    hander['/start'] = requestHandler.start;
    hander['/upload'] = requestHandler.upload;
    server.starts(router.router, hander);



    server.js:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    var http = require('http');
    var url = require('url');
    function start(router, hander) {
        function onRequest(request, response) {
            var pathname = url.parse(request.url).pathname;
            var postData = "";
            request.setEncode = "utf8";
            request.addListener('data', function(postDataChunk){
                postData += postDataChunk;
            })
            request.addListener('end', function(){
                router(pathname, hander, response, postData);
            })
        }
        http.createServer(onRequest).listen(8080);
    }
    exports.starts = start;



    route.js:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    function route(pathname, handler, response, postData) {
        if (typeof(handler[pathname]) === 'function') {
            handler[pathname](response, postData);
            return true;
        } else {
            return false;
        }
    }
    exports.router = route;



    requestHandler.js:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    var querystring = require("querystring");
    function start(response) {
        var body = '<html>' + '<head>' + '<meta http-equiv="Content-Type" content="text/html; ' + 'charset=UTF-8" />' + '</head>' + '<body>' +
        '<form action="/upload" method="post">' + '<textarea name="text" rows="20" cols="60"></textarea>' + '<input type="submit" value="Submit text" />'
    +    '</form>' + '</body>' + '</html>';
        response.write(body);
        response.end();
    }
    function upload(response, postData) {
        response.write("You've sent: " + querystring.parse(postData).text);
        response.end();
    }
    exports.start = start;
    exports.upload = upload;



    访问localhost:8080/start或者localhost:8080;输入数据,提交即可。

  • 相关阅读:
    禁止input密码自动填充及浏览器记住密码完整解决方案
    修改微信小程序的原生button样式
    css 多行超长点点点
    Vue中如何导入并读取Excel数据
    微信小程序 页面打开时scrollview动态滚动到指定位置
    :class和:style的三元表达式
    Vue3.0手机端页面适配屏幕px2rem(自动将px转化为rem)
    9.JavaScript内置对象
    8.JavaScript对象
    7.JavaScript 预解析
  • 原文地址:https://www.cnblogs.com/qiangxia/p/4363232.html
Copyright © 2020-2023  润新知