Express中间件

什么是中间件

中间件(Middleware) 本质是一个回调函数。

中间件函数 可以像路由回调一样访问 请求对象、响应对象。

中间件的作用

中间件的作用就是使用函数封装公共操作,简化代码。

中间件的类型

全局中间件

定义全局中间件

每一个请求 到达服务端之后 都会执行全局中间件函数。

声明中间件函数

javascript 复制代码
let recordMiddleware = function (request, response, next) {
  //实现功能代码
  //.....
  //执行next函数(当如果希望执行完中间件函数之后,仍然继续执行路由中的回调函数,必须调用next)
  next();
}

应用级中间件

javascript 复制代码
app.use(recordMiddleware);

声明时可以直接将匿名函数传递给 use

javascript 复制代码
app.use(function (request, response, next) {
  console.log('定义第一个中间件');
  next();
})
多个全局中间件

Express允许使用app.use() 定义多个全局中间件

javascript 复制代码
app.use(function (request, response, next) {
  console.log('定义第一个中间件');
  next();
})
app.use(function (request, response, next) {
  console.log('定义第二个中间件');
  next();
})

路由中间件

定义路由中间件

如果只需要对某一些路由进行功能封装,则就需要路由中间件

调用格式如下:

javascript 复制代码
app.get('/路径', `中间件函数`, (request, response) => {
});
app.get('/路径', `中间件函数1`, `中间件函数2`, (request, response) => {
});

静态资源中间件

Express内置处理静态资源的中间件

javascript 复制代码
//引入express框架
const express = require('express');
//创建服务对象
const app = express();
//静态资源中间件的设置,将当前文件夹下的public目录作为网站的根目录
app.use(express.static('./public')); //当然这个目录中都是一些静态资源
//如果访问的内容经常变化,还是需要设置路由
//但是,在这里有一个问题,如果public目录下有index.html文件,单独也有index.html的路由,
//则谁书写在前,优先执行谁
app.get('/index.html', (request, response) => {
  respsonse.send('首页');
});
//监听端口
app.listen(3000, () => {
  console.log('3000 端口启动....');
});

注意事项:

  1. index.html 文件为默认打开的资源
  2. 如果静态资源与路由规则同时匹配,谁先匹配谁就响应
  3. 路由响应动态资源,静态资源中间件响应静态资源

获取请求体数据body-parser

Express可以使用 body-parser 包处理请求体

第一步:安装

javascript 复制代码
npm i body-parser

第二步:导入body-parser包

javascript 复制代码
const bodyParser = require('body-parser');

第三步:获取中间件函数

javascript 复制代码
//处理 querystring 格式的请求体
let urlParser = bodyParser.urlencoded({extended:false}));
//处理 JSON 格式的请求体
let jsonParser = bodyParser.json();

第四步:设置路由中间件,然后使用request.body来获取请求体数据

javascript 复制代码
app.post('/login', urlParser, (request, response) => {
  //获取请求体数据
  //console.log(request.body);
  //用户名
  console.log(request.body.username);
  //密码
  console.log(request.body.userpass);
  response.send('获取请求体数据');
});

获取到的请求体数据为

javascript 复制代码
[Object: null prototype] { username: 'admin', userpass: '123456' }
相关推荐
小杨升级打怪中5 小时前
前端面经-webpack篇--定义、配置、构建流程、 Loader、Tree Shaking、懒加载与预加载、代码分割、 Plugin 机制
前端·webpack·node.js
程序员拂雨12 小时前
Node.js中的URL模块
node.js
运维成长记15 小时前
mysql数据库-中间件MyCat
数据库·mysql·中间件
低代码布道师15 小时前
第五部分:第五节 - Express 路由与中间件进阶:厨房的分工与异常处理
中间件·express
TiDB 社区干货传送门16 小时前
从开发者角度看数据库架构进化史:JDBC - 中间件 - TiDB
数据库·oracle·中间件·tidb·数据库架构
欧先生^_^1 天前
Node.js 源码架构详解
架构·node.js
沐土Arvin1 天前
从零开始认识 Node.js:异步非阻塞的魅力
node.js
TE-茶叶蛋1 天前
Node.js中的洋葱模型
node.js
Q_Q19632884751 天前
python的漫画网站管理系统
开发语言·spring boot·python·django·flask·node.js·php
outstanding木槿1 天前
react中安装依赖时的问题 【集合】
前端·javascript·react.js·node.js