zoukankan      html  css  js  c++  java
  • Node.js中的express框架获取http参数

    最近本人在学习开发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代码

    <form action="/index" method="get">  
           <input type="text" name="login_name"/>  
         <input type="submit" value="Sign In" />  
    </form> 
    在nodeJs中我们要自定义HTTP,因此创建index.js
    var app = require('express').createServer();  
      
    app.get('/:key', function(req, res){  
      console.log(req.params.key);//输出index   
      console.log(req.query.login_name);//输出表单get提交的login_name   
      res.send('great you are right for get method!');//显示页面文字信息   
    });  
    app.post('/:key', function(req, res){  
    <pre name="code" class="javascript">  console.log(req.params.key);//输出index   
      console.log(req.body.login_name);//输出表单post提交的login_name   
      res.send('great you are right for post method!');//显示页面文字信息 
    });app.listen(3000);

    之后运行node index.js就可以看到本效果,当然前提是你要先访问test.html,至于如何通过express访问一个html文件我就不详细描述了,可以参考如下代码:
    global.fs=require('fs');          
    var realpath = VIEW + "test.html";  
    var file = fs.readFileSync(realpath);  
    res.end(file); 
    更多关于Node.js的详细信息,或者下载地址请点这里

    本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2012-04/58730.htm

  • 相关阅读:
    w3c标准
    HTML+CSS理解
    Mybatis源码日记(一)
    Sqlmap学习笔记(三)
    EasyExcel读取跨行单元格数据为空的解决办法
    Sqlmap学习笔记(二)
    Sqlmap学习笔记(一)
    Linux安装运行Typora
    Kafka环境搭建
    Mysql主从配置
  • 原文地址:https://www.cnblogs.com/youfeng365/p/5846773.html
Copyright © 2011-2022 走看看