zoukankan      html  css  js  c++  java
  • Express全系列教程之(五):Express的中间件

     

    一、中间件

    从字面意思,我们可以了解到它大概就是做中间代理操作,事实也是如此;大多数情况下,中间件就是在做接收到请求和发送响应中间的一系列操作。事实上,express是一个路由和中间件的web框架,Express 应用程序基本上是一系列中间件函数的调用。

    中间件函数可以执行以下任务:
    执行任何代码。
    对请求和响应对象进行更改。
    结束请求/响应循环。
    调用堆栈中的下一个中间件函数。

    中间件也分为应用层中间件、路由中间件、内置中间件、错误处理中间件和第三方中间件。下面分别对以下进行说明:

    1.应用层中间件

    应用级中间键绑定到app对象使用app.use和app.METHOD()-需要处理http请求的方法,例如GET、PUT、POST,将之前的get或者post替换为use就行。
    例如下面实例:

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    const express=require("express");

    var app=express();

    //匹配路由之前的操作

    app.use(function(req,res){

        console.log("访问之前");

    });

    app.get("/",function(req,res){

        res.send("主页");

    });

    app.listen(8080);

    这时我们会发现http://localhost:8080/地址一直在加载,但命令行里显示了“访问之前”,说明程序并不会同步执行,如果使用next来是路由继续向下匹配,那么就能又得到主页数据了:

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    const express=require("express");

    var app=express();

    //匹配路由之前的操作

    app.use(function(req,res,next){

        console.log("访问之前");

        next();

    });

    app.get("/",function(req,res){

        res.send("主页");

    });

    app.listen(8080);

      当然也可以简化写法:

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    const express=require("express");

    var app=express();

    app.use(function(req,res,next){

        console.log("访问之前");

        next();

    },function(req,res){

        res.send("主页");

    });

    app.listen(8080);

      因此,在进行路由匹配之前或再录又要继续向下执行时想做个操作,那么应用层中间件无疑是好的选择。

    2.路由中间件

    路由级中间件和应用级中间件类似,只不过他需要绑定express.Router();

    1

    var router = express.Router()

      在匹配路由时,我们使用 router.use() 或 router.VERB() ,路由中间件结合多次callback可用于用户登录及用户状态检测。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    const express = require("express");

    var app = express();

    var router=express.Router();

    router.use("/",function(req,res,next){

        console.log("匹配前");

        next();

    });

    router.use("/user",function(req,res,next){

        console.log("匹配地址:",req.originalUrl);

        next();

    },function(req,res){

        res.send("用户登录");

    });

    app.use("/",router);

    app.listen(8080);

      总之在检测用户登录和引导用户应该访问哪个页面是,路由中间件绝对好用。

    3.错误处理中间件

    顾名思义,它是指当我们匹配不到路由时所执行的操作。错误处理中间件和其他中间件基本一样,只不过其需要开发者提供4个自变量参数。

    1

    2

    3

    app.use((err, req, res, next) => {

            res.sendStatus(err.httpStatusCode).json(err);

    });

      一般情况下,我们把错误处理放在最下面,这样我们即可对错误进行集中处理。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    const express=require("express");

    var app=express();

    app.get("/",function(req,res,next){

        const err=new Error('Not Found');

        res.send("主页");

        next(err);

    });

    app.use("/user",function(err,req,res,next){

        console.log("用户登录");

        next(err);

    },function(req,res,next){

        res.send("用户登录");

        next();

    });

    app.use(function(req,res){

        res.status(404).send("未找到指定页面");

    });

    app.listen(8080);

      

    4.内置中间件

    从版本4.x开始,Express不再依赖Content,也就是说Express以前的内置中间件作为单独模块,express.static是Express的唯一内置中间件。

    1

    express.static(root, [options]);

      通过express.static我们可以指定要加载的静态资源。root代表加载静态资源的路径,options作为可选参数拥有一下属性:

     
    属性 描述 类型 缺省值
    dotfiles 是否对外输出文件名以点(.)开头的文件。有效值包括“allow”、“deny”和“ignore” 字符串 “ignore”
    etag 启用或禁用 etag 生成 布尔 true
    extensions 用于设置后备文件扩展名。 数组 []
    index 发送目录索引文件。设置为 false 可禁用建立目录索引。 混合 “index.html”
    lastModified 将 Last-Modified 的头设置为操作系统上该文件的上次修改日期。有效值包括 true 或 false。 布尔 true
    maxAge 设置 Cache-Control 头的 max-age 属性(以毫秒或者 ms 格式中的字符串为单位) 数字 0
    redirect 当路径名是目录时重定向到结尾的“/”。 布尔  
    setHeaders 用于设置随文件一起提供的 HTTP 头的函数。 函数 true

    以下示例将使用了 express.static 中间件,并且提供了一个详细的’options’对象(作为示例):

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    var options = {

      dotfiles: 'ignore',

      etag: false,

      extensions: ['htm''html'],

      index: false,

      maxAge: '1d',

      redirect: false,

      setHeaders: function (res, path, stat) {

        res.set('x-timestamp', Date.now());

      }

    }

    app.use(express.static('public', options));

    5.第三方中间件

    形如之前我们的body-parser,采用引入外部模块的方式来获得更多的应用操作。如后期的cookie和session。

    1

    2

    3

    var express = require('express');

    var app = express();

    var cookieParser = require('cookie-parser');

      以上就是关于express中间件类型,在实际项目中,中间件都是必不可少的,因此熟悉使用各种中间件会加快项目的开发效率。

  • 相关阅读:
    win8平板App文件上传
    win8 APP中网页js如何触发后台的ScriptNotify方法
    lsof list open files
    python下的一个人脸识别包
    mysql hex() and unhex()
    git 补丁git formatpatch
    perl sort
    git 分支无法checkout的解决办法
    PERL 语言中的q,qw,qr,qx,qq......符号用法总结
    perl 的真假值
  • 原文地址:https://www.cnblogs.com/wjlbk/p/12633310.html
Copyright © 2011-2022 走看看