Express框架两个内置中间件方法详解

 更新时间:2023年03月07日 14:49:35   作者:乔治_x  
这篇文章主要为大家介绍了Express框架两个内置中间件方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

什么是中间件

中间件,就是具有串联执行能力的函数,Express中两种层面的中间件。app 层面的中间件, router 层面的中甲件。在 express 中, 一般通过 use 方法和路由的方法添加中间件。

两个内置的中间件

  • init 中间件方法
  • query 中间件方法

init 方法

exports.init = function(app){
  return function expressInit(req, res, next){
    if (app.enabled('x-powered-by')) res.setHeader('X-Powered-By', 'Express');
    req.res = res;
    res.req = req;
    req.next = next;
    setPrototypeOf(req, app.request)
    setPrototypeOf(res, app.response)
    res.locals = res.locals || Object.create(null);
    next();
  };
};

expressInit 中间件:

  • 设置 'X-Powered-By' 请求头
  • req/res 对象上添加属性
  • 绑定原型
  • 设置 local
  • 调用 next 方法

query 中间件

module.exports = function query(options) {
  var opts = merge({}, options)
  var queryparse = qs.parse;
  if (typeof options === 'function') {
    queryparse = options;
    opts = undefined;
  }
  if (opts !== undefined && opts.allowPrototypes === undefined) {
    // back-compat for qs module
    opts.allowPrototypes = true;
  }
  return function query(req, res, next){
    if (!req.query) {
      var val = parseUrl(req).query;
      req.query = queryparse(val, opts);
    }
    next();
  };
};

返回一个 query 函数,在 query 函数中使用 parseUrl 和 queryparse 处理了 url 中 query, 到此就恶意直接在 req 中使用 query 了。

exports.query = require('./middleware/query');

query 中间件被输出了,可以手动调用。

被使用

app.lazyrouter = function lazyrouter() {
  if (!this._router) {
    this._router = new Router({
      caseSensitive: this.enabled('case sensitive routing'),
      strict: this.enabled('strict routing')
    });
    this._router.use(query(this.get('query parser fn')));
    this._router.use(middleware.init(this));
  }
};

在调用 lazyrouter 函数的地方,都会使用 use 函数添加中间件函数。每一个 app 初始化都会注入此两个中间件。

小结

本文介绍了中间件的简单定义,具有串联的特性,以及 Express 中两个内置中间件,一个是 exprss 初始中间件,一个时 express 的 query 中间件。内置 query 中间件被输出可别外部使用,同时在 app.lazyrouter 中被初始化。

更多关于Express框架内置中间件的资料请关注脚本之家其它相关文章!

相关文章

  • 微信小程序 教程之条件渲染

    微信小程序 教程之条件渲染

    这篇文章主要介绍了微信小程序 条件渲染的相关资料,并附简单实例代码,需要的朋友可以参考下
    2016-10-10
  • 关于js typeof 与 instanceof 判断数据类型区别及开发使用

    关于js typeof 与 instanceof 判断数据类型区别及开发使用

    我们经常会遇到判断一个变量的数据类型或该变量是否为空值的情况,你是如何去选择判断类型操作符的?本文来记录一下我们开发人员必须掌握关于 typeof 和 instanceof 的知识点及在开发中的使用建议,同时在面试过程中也经常会遇到这样的问题,需要的朋友可参考下文章内容
    2021-10-10
  • JS前端面试手写apply和bind实例

    JS前端面试手写apply和bind实例

    这篇文章主要为大家介绍了JS前端面试手写apply和bind实例的轻松实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Typescript 封装 Axios拦截器方法实例

    Typescript 封装 Axios拦截器方法实例

    这篇文章主要为大家介绍了Typescript 封装 Axios拦截器方法实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • 详解微信小程序 登录获取unionid

    详解微信小程序 登录获取unionid

    这篇文章主要介绍了详解微信小程序 登录获取unionid的相关资料,需要的朋友可以参考下
    2017-06-06
  • 微信小程序 数据绑定详解及实例

    微信小程序 数据绑定详解及实例

    这篇文章主要介绍了微信小程序 数据绑定详解及实例的相关资料,需要的朋友可以参考下
    2016-10-10
  • Moment的feature导致线上bug解决分析

    Moment的feature导致线上bug解决分析

    这篇文章主要为大家介绍了Moment的feature导致线上bug解决分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • 微信小程序 wxapp内容组件 text详细介绍

    微信小程序 wxapp内容组件 text详细介绍

    这篇文章主要介绍了微信小程序 wxapp内容组件 text详细介绍的相关资料,并附简单实例代码,需要的朋友可以参考下
    2016-10-10
  • TypeScript与JavaScript对比及打包工具比较

    TypeScript与JavaScript对比及打包工具比较

    这篇文章主要为大家介绍了TypeScript与JavaScript对比及打包工具比较,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • 详解Jest 如何支持异步及时间函数实现示例

    详解Jest 如何支持异步及时间函数实现示例

    这篇文章主要为大家介绍了Jest 如何支持异步及时间函数实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09

最新评论