node.js解析http请求数据

来源:互联网 发布:java趣味小程序 编辑:程序博客网 时间:2024/06/05 09:00

最近本人在学习开发NodeJs,使用到express框架,对于网上的学习资料甚少,因此本人会经常在开发中做一些总结。

express获取参数有三种方法:官网介绍如下

  • Checks route params (req.params), ex: /user/:id
  • Checks query string params (req.query), ex: ?id=12
  • Checks urlencoded body params (req.body), ex: id=
1、例如:127.0.0.1:3000/index,这种情况下,我们为了得到index,我们可以通过使用req.params得到,通过这种方法我们就可以很好的处理Node中的路由处理问题,同时利用这点可以非常方便的实现MVC模式;

2、例如:127.0.0.1:3000/index?id=12,这种情况下,这种方式是获取客户端get方式传递过来的值,通过使用req.query.id就可以获得,类似于PHP的get方法;

3、例如:127.0.0.1:300/index,然后post了一个id=2的值,这种方式是获取客户端post过来的数据,可以通过req.body.id获取,类似于PHP的post方法;


下面举例介绍下这三个方法:

如下一个test.html代码

[html] view plaincopyprint?
  1. <form action="/index" method="get">  
  2.        <input type="text" name="login_name"/>  
  3.      <input type="submit" value="Sign In" />  
  4. </form>  

在nodeJs中我们要自定义HTTP,因此创建index.js

[javascript] view plaincopyprint?
  1. var app = require('express').createServer();  
  2.   
  3. app.get('/:key'function(req, res){  
  4.   console.log(req.params.key);//输出index  
  5.   console.log(req.query.login_name);//输出表单get提交的login_name  
  6.   res.send('great you are right for get method!');//显示页面文字信息  
  7. });  
  8. app.post('/:key'function(req, res){  
  9. <pre name="code" class="javascript">  console.log(req.params.key);//输出index  
  10.   console.log(req.body.login_name);//输出表单post提交的login_name  
  11.   res.send('great you are right for post method!');//显示页面文字信息</pre>});app.listen(3000);  
  12. <pre></pre>  
  13. <p></p>  
  14. <pre></pre>  
  15. <span style="font-size:18px">之后运行node index.js就可以看到本效果,当然前提是你要先访问test.html,至于如何通过express访问一个html文件我就不详细描述了,可以参考如下代码:</span>  
  16. <p></p>  
  17. <p></p>  
  18. <pre name="code" class="javascript">global.fs=require('fs');          
  19. var realpath = VIEW + "test.html";  
  20. var file = fs.readFileSync(realpath);  
  21. res.end(file);</pre><span style="font-size:18px; color:#ff0000"><strong><br>  
  22. 欢迎加入我们的Node学习行列,我们主群:33326910进群请备注“Node”,我个人node技术群:143749960<br>  
  23. </strong></span><br>  
  24. <p></p>  
  25. <p><br>  
  26. </p>  
  27. <p><br>  
  28. </p>  
  29. <p><br>  
  30. </p>  
  31. <p><br>  
  32. </p>  
  33. <pre></pre>  
  34. <pre></pre>  
  35.      
0 0