zoukankan      html  css  js  c++  java
  • Node: Express的Route路由的使用

    一、简介

    一个Web服务器去处理每一个URL请求时,根据监听的端口和主机域名,需要对不同的路径去处理然后给出不同的响应。也即通过制定不同的路径,调用对应处理用户的请求。这个路径的制定就是路由。路由其实是一种规则而已。开发者根据这个规则去制定请求的目标地址,服务器根据这个规则去响应请求的目标地址并给出对应的响应结果。定义路由的方式有两种,第一种就是根据请求的方法名进行区分,例如GET请求或者POST请求。另一种就是通过路由的路径uri来区分。

    二、路由的定义和区分

    1、创建和启动服务

    //导入express框架
    const express = require('express');
    
    //创建express服务实例
    const app = express();
    
    //监听
    app.listen(3000, ()=>{
        console.log('服务器启动了!');
    }); 
    //启动结果如下:
    xiayuanquan@XYQ � ~/Desktop/开发案例/NodeApp/express-route-demo � npm start
    
    > express-route-demo@1.0.0 start /Users/xiayuanquan/Desktop/开发案例/NodeApp/express-route-demo
    > nodemon src/app.js
    
    [nodemon] 2.0.2
    [nodemon] to restart at any time, enter `rs`
    [nodemon] watching dir(s): *.*
    [nodemon] watching extensions: js,mjs,json
    [nodemon] starting `node src/app.js`
    服务器启动了!

    2、定义路由

    方式一:通过GET和POST等方法名区分路由

    //导入express框架
    const express = require('express');
    
    //创建express服务实例
    const app = express();
    
    //通过请求的方法类型 get/post/put/delete... 定制路由
    app.get('/demo', (req, res) => {
        //req:请求对象
        //res:服务响应对象
        res.json({
            message:'hello express route form get method'
        })
    });
    app.post('/demo', (req, res) => {
        //req:请求对象
        //res:服务响应对象
        res.json({
            message:'hello express route form post method'
        })
    });
    
    //监听
    app.listen(3000, ()=>{
        console.log('服务器启动了!');
    });

    使用Postman,访问相同的路由,根据不同的方法名,得到的响应不同,截图如下:

     

    方式二:通过uri路径

    //导入express框架
    const express = require('express');
    
    //创建express服务实例
    const app = express();
    
    //通过 uri 定制路由, 分别通过"/user/byname"和"/user/byuserId"访问
    app.get('/user/byname', (req, res) => {
        let {name} = req.query; //将请求参数析构
        res.json({
            name
        })
    });
    app.get('/user/byuserId', (req, res) => {
        let {userid} = req.query; //将请求参数析构
        res.json({
            userid
        })
    });
    
    //监听
    app.listen(3000, ()=>{
        console.log('服务器启动了!');
    });

    使用Postman,根据不同的uri路径进行访问,得到的响应不同,截图如下:

     

    三、app.all()函数和app.use()函数

    介绍了路由的定义和区分,接下来我们来对路由的常用的两个函数all()和use()进行一些简单的使用。场景示例如下:

    1、定义一个 api/路由,满足无论使用什么请求方式(get/post/put....)都可以得到响应。

    //导入express框架
    const express = require('express');
    
    //创建express服务实例
    const app = express();
    
    //使用app.all()函数和app.use()函数都可以实现该目的
    
    //使用 app.all()函数
    app.all('/demo', (req, res) => {
        res.json({
            message: 'demo',
            method: req.method
        })
    })
    
    /*
    //使用 app.use()函数 【将路由作为中间件使用】
    app.use('/demo', (req, res) => {
        res.json({
            message: 'demo',
            method: req.method
        })
    })
    */
    
    //监听
    app.listen(3000, ()=>{
        console.log('服务器启动了!');
    }); 
    //此处不再截图展示,直接显示Postman的请求结果如下:
    
    //GET方式
    {
        "message": "demo",
        "method": "GET"
    }
    
    //POST方式
    {
        "message": "demo",
        "method": "POST"
    }
    
    //PUT方式
    {
        "message": "demo",
        "method": "PUT"
    }
    
    .....................

    2、无论客户端使用任意的uri ,服务都可以得到相应。

    //导入express框架
    const express = require('express');
    
    //创建express服务实例
    const app = express();
    
    //使用app.all() 和 app.use() 函数都可以实现该目的
    
    //使用 app.all()函数
    app.all('*', (req, res) => {
        res.json({
            message: 'demo',
            method: req.method,
            uri: req.path
        })
    })
    
    /*
    //使用app.use()函数。【将路由作为中间件使用】
    app.use((req, res)=>{
        res.json({
            message: 'demo',
            method: req.method,
            uri: req.path
        })
    })
    */
    
    //监听
    app.listen(3000, ()=>{
        console.log('服务器启动了!');
    }); 
    //此处不再截图展示,直接显示Postman的请求结果如下:
    
    //通过GET方式访问"http://127.0.0.1:3000/123",uri为"/123"
    {
        "message": "demo",
        "method": "GET",
        "uri": "/123"
    }
    
    //通过GET方式访问"http://127.0.0.1:3000/123/xiayuanquan",uri为"/123/xiayuanquan"
    {
        "message": "demo",
        "method": "GET",
        "uri": "/123/xiayuanquan"
    }
    
    //通过POST方式访问"http://127.0.0.1:3000/demo/123/xiayuanquan/xxx",uri为"/demo/123/xiayuanquan/xxx"
    {
        "message": "demo",
        "method": "POST",
        "uri": "/demo/123/xiayuanquan/xxx"
    }
    
    .................................................

     

    三、路由的拆分

    团队开发时,这么多人不希望都在一个文件做修改,此时可以对路由进行拆分。express提供了一个express.Router()函数创建路由实例。在拆分路由时,需要根据对应的需求单独建立自己的路由文件,定义好自己的路由后,只需要暴露出来,然后在同一的服务文件注册即可。例如创建了member.router.js和user.router.js文件,然后在app.js中注册路由,文件如下:

    member.router.js

    //导入express框架
    const express = require('express');
    
    //定一个member路由
    const router = express.Router();
    
    //使用get请求
    router.get('/member/list', (req, res) => {
        res.json({
            list:[
                {
                    name:"张三",
                    age:20,
                },
                {
                    name:"李四",
                    age:30,
                }
            ]
        })
    })
    
    //将路由暴露出来
    module.exports = router;

    user.router.js

    //导入express框架
    const express = require('express');
    
    //定一个user路由
    const router = express.Router();
    
    //使用get请求
    router.post('/user/list', (req, res) => {
        res.json({
            list:[
                {
                    id: 1111,
                    name:"Job"
                },
                {
                    id: 2222,
                    name:"Tom"
                }
            ]
        })
    })
    
    //将路由暴露出来
    module.exports = router;

    app.js

    //导入express框架
    const express = require('express');
    
    //创建express服务实例
    const app = express();
    
    //导入路由文件
    const memberRouter = require('./member.router');
    const userRouter = require('./user.router');
    
    //注册路由
    //使用app.use()函数可以分开写,可以连着写,即函数式编程, 例如:app.use(memberRouter).use(userRouter);
    //注意:这两个路由除去"http://127.0.0.1:3000"后的如果是同一个,假如都是"/list"。在注册时,可以在use()函数添加前缀,类似命名空间,例如:
    //app.use('/member',memberRouter);
    //app.use('/user',userRouter);
    //然后,访问时,路由的地址可以不用改变了,都是"http://127.0.0.1:3000/list"
    app.use(memberRouter); app.use(userRouter); //监听 app.listen(3000, ()=>{ console.log('服务器启动了!'); });

    在Postman中,分别访问对应路由组件的api请求,此处定义的路由的uri不一样,所以可以区分访问,访问结果分别如下:

    四、API

    更多关于Express路由的使用,请参考官方文档:http://www.expressjs.com.cn/guide/routing.html

  • 相关阅读:
    查询数据库对象依赖关系
    SQL Server数据库管理员必备:DBCC命令
    使用延迟的FileSystemWatcher来避免重复触发事件
    在Lambda表达式中使用递归
    如何观察SQL Server 生成和重用执行计划
    利用Lambda表达式、扩展方法以及泛型来实现一个另类的AOP
    将 SQL Server 2000 系统表映射到 SQL Server 2005 系统视图[MSDN]
    利用Lambda表达式、扩展方法以及泛型来为对象添加方法
    C# 中编译器是如何实现闭包的
    在ASP.NET中使用FileSystemWatcher来监控文件目录
  • 原文地址:https://www.cnblogs.com/XYQ-208910/p/12116133.html
Copyright © 2011-2022 走看看