middleware中间件的概念

简要来说express就是一个由路由和中间件构成的 web 开发框架。

当express服务收到客户端的请求时,会通过一组函数来处理请求。

这些函数用于解析请求体数据,处理错误,或者负责返回各种情况对应的消息,这种函数就叫中间件。

express中的中间件函数形如:

app.use(function middleware1(req, res, next){
  // logic
});

req是请求体,附带着各种请求信息的属性,res附带返回信息的一些方法。

每个中间件应该只处理一种情况,并且,这些函数参数中的req是同一个对象。

因此,前面的中间件如果修改了req,后面的会得到修改后的对象。

当中间件接收到的req已经处理完了,或是没有达到处理条件,就调用next方法跳到下一个中间件处理。

如果既没调用res返回信息,也没调用next跳过,服务就会处于挂起状态。

默认的,如果一个请求跳过了所有中间件也没有得到返回,express会返回500返回码。 


 一个完整的事例

var express = require('express');
var app = express();

app.use(function(req,res,next){
  // 这里可以访问req.body 来查看请求的参数
  // 通过调用res.send() 来发送信息

  // 没有该中间件要处理的情况 调用next跳到下一个中间件
});

当然,express在这基础上做了一些封装,减少了代码量。

例如要限定中间件所处理的uri,可以这么写

app.use('/requestURI', function(req,res,next){
  // 这里当请求的uri跟指定uri不符,自动跳过该中间件
});

除了uri外,还可以根据请求方法来限制

app.use('/requestURI', function(req, res, next){
  if('get' !== req.method.toLowercase()) next();

  // your logic
});

相当于

app.get('/requestURI', function(req, res, next){
  // your logic
});

 组合起来

app.get('/requestURI', function(req, res, next){
  // your logic
});

express支持get, post, put, delete等动词方法。


中间件对参数的支持。

当我们需要在uri中加入查询参数时,可以这么写

app.use('/requireURI/:qurey', functinor(req, res, next){
  console.log(req.params.qures);
});

 

 

 

 

通过express我们可以快速开发一个web应用。

转载于:https://www.cnblogs.com/ohmyladygaga/p/6149489.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值