详解Node.Js如何处理post数据


Posted in Javascript onSeptember 19, 2016

实现思路

将data和end事件的回调函数直接放在服务器中,在data事件回调中收集所有的POST数据,当接收到所有数据,触发end事件后,其回调函数调用请求路由,并将数据传递给它,然后,请求路由再将该数据传递给请求处理程序。

实现步骤

第一步我们设置了接收数据的编码格式为UTF-8,第二步注册了“data”事件的监听器,用于收集每次接收到的新数据块,并将其赋值给postData 变量,最后第三步我们将请求路由的调用移到end事件处理程序中,以确保它只会当所有数据接收完毕后才触发,并且只触发一次。我们同时还把POST数据传递给请求路由

示例代码

index.js

var server = require("./server"); 
var router=require("./router"); 
var requestHandlers=require("./requestHandlers"); 
 
var handle = {} 
handle["/"] = requestHandlers.start; 
handle["/start"] = requestHandlers.start; 
handle["/upload"] = requestHandlers.upload; 
 
server.start(router.route,handle);

server.js

var http = require("http"); 
var url=require("url"); 
 
function start(route,handle) { 
 function onRequest(request, response) { 
  var postData=""; 
    var pathname=url.parse(request.url).pathname; 
  console.log("Request for"+pathname+"received."); 
    
   request.setEncoding("utf8"); 
    
   request.addListener("data", function(postDataChunk) { 
     postData += postDataChunk; 
     console.log("Received POST data chunk '"+ 
     postDataChunk + "'."); 
  }); 
 
  request.addListener("end", function() { 
   route(handle, pathname, response, postData); 
  }); 
    //route(handle,pathname,response); 
   
  //response.writeHead(200, {"Content-Type": "text/plain"}); 
  //response.write("this is a demo"); 
  //response.end(); 
 } 
 
 http.createServer(onRequest).listen(5656,'127.0.0.1'); 
 console.log("Server has started. localhost:5656"); 
} 
 
exports.start = start;

router.js

function route(handle,pathname,response,postData){ 
  console.log("About to route a request for"+pathname); 
  if(typeof handle[pathname]=='function'){ 
    handle[pathname](response,postData); 
  } 
  else{ 
    console.log("no request handler found for"+pathname); 
    response.writeHead(404, {"Content-Type": "text/plain"}); 
  response.write("404 Not found"); 
  response.end(); 
  } 
} 
exports.route=route;

requestHandlers.js

//var querystring = require("querystring"); 
 
function start(response,postData) { 
 console.log("Request handler 'start' was called."); 
 
 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.writeHead(200, {"Content-Type": "text/html"}); 
  response.write(body); 
  response.end(); 
} 
 
function upload(response,postData) { 
 console.log("Request handler 'upload' was called."); 
 response.writeHead(200, {"Content-Type": "text/plain"}); 
 response.write("You've sent: " + postData); 
 response.end(); 
} 
 
exports.start = start; 
exports.upload = upload;

运行:node mynode/index

浏览器输入http://localhost:5656/

详解Node.Js如何处理post数据

结果:

详解Node.Js如何处理post数据

在文本框里输入“I LOVE YOU” 点击提交

详解Node.Js如何处理post数据

详解Node.Js如何处理post数据

使用querystring模块只提取文本,修改一下requestHandlers.js使只返回文本

var querystring = require("querystring"); 
 
function start(response,postData) { 
 console.log("Request handler 'start' was called."); 
 
 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.writeHead(200, {"Content-Type": "text/html"}); 
  response.write(body); 
  response.end(); 
} 
 
function upload(response,postData) { 
 console.log("Request handler 'upload' was called."); 
 response.writeHead(200, {"Content-Type": "text/plain"}); 
 response.write("You've sent: " + querystring.parse(postData).text); 
 response.end(); 
} 
 
exports.start = start; 
exports.upload = upload;

重新启动,依旧输入I LOVE YOU ,提交

详解Node.Js如何处理post数据

总结

以上就是这篇文章的全部内容了,希望这篇文章的内容对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
jQeury淡入淡出需要注意的问题
Sep 08 Javascript
谈谈JavaScript自定义回调函数
Oct 18 Javascript
javascript跨域的方法汇总
Oct 23 Javascript
easyui中combotree循环获取父节点至根节点并输出路径实现方法
Nov 10 Javascript
移动开发之自适应手机屏幕宽度
Nov 23 Javascript
深入理解ES7的async/await的用法
Sep 09 Javascript
纯html+css+javascript实现楼层跳跃式的页面布局(实例代码)
Oct 25 Javascript
微信小程序项目实践之主页tab选项实现
Jul 18 Javascript
浅谈react性能优化的方法
Sep 05 Javascript
详解Vue前端对axios的封装和使用
Apr 01 Javascript
Vue入门学习笔记【基本概念、对象、过滤器、指令等】
Apr 13 Javascript
Angular之jwt令牌身份验证的实现
Feb 14 Javascript
React Native实现简单的登录功能(推荐)
Sep 19 #Javascript
在Web项目中引入Jquery插件报错的完美解决方案(图解)
Sep 19 #Javascript
BootStrap入门教程(二)之固定的内置样式
Sep 19 #Javascript
BootStrap入门教程(一)之可视化布局
Sep 19 #Javascript
Node.js的基本知识简单汇总
Sep 19 #Javascript
React实现双向绑定示例代码
Sep 19 #Javascript
vue从使用到源码实现教程详解
Sep 19 #Javascript
You might like
php全局变量和类配合使用深刻理解
2013/06/05 PHP
PHP获取文件夹大小函数用法实例
2015/07/01 PHP
浅谈PHP之ThinkPHP框架使用详解
2020/07/21 PHP
jquery.cookie用法详细解析
2013/12/18 Javascript
提升PHP安全:8个必须修改的PHP默认配置
2014/11/17 Javascript
javascript中eval解析JSON字符串
2016/02/27 Javascript
BootStrap中Tab页签切换实例代码
2016/05/30 Javascript
jQuery animate easing使用方法图文详解
2016/06/17 Javascript
深入理解在JS中通过四种设置事件处理程序的方法
2017/03/02 Javascript
angularjs利用directive实现移动端自定义软键盘的示例
2017/09/20 Javascript
js断点调试心得分享(必看篇)
2017/12/08 Javascript
vue+axios 拦截器实现统一token的案例
2020/09/11 Javascript
[42:56]VGJ.S vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
Python的Django框架中的Context使用
2015/07/15 Python
小议Python中自定义函数的可变参数的使用及注意点
2016/06/21 Python
Python用threading实现多线程详解
2017/02/03 Python
详解python 字符串和日期之间转换 StringAndDate
2017/05/04 Python
Python编程之Re模块下的函数介绍
2017/10/28 Python
Python爬虫信息输入及页面的切换方法
2018/05/11 Python
通过PHP与Python代码对比的语法差异详解
2019/07/10 Python
opencv转换颜色空间更改图片背景
2019/08/20 Python
阿里云ECS服务器部署django的方法
2019/08/29 Python
Django 框架模型操作入门教程
2019/11/05 Python
使用python turtle画高达
2020/01/19 Python
Python Selenium安装及环境配置的实现
2020/03/17 Python
html5调用app分享功能示例(WebViewJavascriptBridge)
2018/03/21 HTML / CSS
业绩考核岗位职责
2014/02/01 职场文书
党风廉设责任书
2014/04/16 职场文书
2014教师研修学习体会
2014/07/08 职场文书
2014年管理人员工作总结
2014/12/01 职场文书
教师调动申请报告
2015/05/18 职场文书
2016应届大学生自荐信模板
2016/01/28 职场文书
四年级数学教学反思
2016/02/16 职场文书
初一语文教学反思
2016/03/03 职场文书
python 爬取天气网卫星图片
2021/06/07 Python
Hive日期格式转换方法总结
2022/06/25 数据库