中间件(express)

中间件(express)

在Express.js中,中间件(Middleware)是一个重要的组成部分,用于处理HTTP请求和响应。中间件函数具有特定的签名,并可以接受请求对象(req)、响应对象(res)以及一个可选的next函数作为参数。

中间件函数可以对请求和响应对象执行各种任务,例如执行身份验证、解析数据、压缩响应等。如果中间件函数没有结束请求-响应循环(例如,没有调用res.end()或res.send()),那么它应该调用next()函数将控制权传递给下一个中间件。
下面是一个Express中间件的基本示例:

javascript 复制代码
const express = require('express');  
const app = express();  
  
// 中间件函数  
function logger(req, res, next) {  
  console.log('Logging:', req.method, req.url);  
  next(); // 调用下一个中间件  
}  
  
// 另一个中间件函数,用于检查用户是否已登录  
function authenticate(req, res, next) {  
  // 假设我们有一个检查用户是否已登录的方法  
  const isAuthenticated = req.isAuthenticated(); // 伪代码  
  if (isAuthenticated) {  
    next(); // 用户已登录,继续处理  
  } else {  
    res.status(401).send('Unauthorized'); // 用户未登录,返回401状态码  
  }  
}  
  
// 路由处理程序  
function homePage(req, res) {  
  res.send('Home Page');  
}  
  
// 使用中间件  
app.use(logger); // 应用于所有请求  
  
// 特定路由的中间件  
app.get('/protected', authenticate, homePage); // 先进行身份验证,再访问主页  
  
// 未保护的路由  
app.get('/', homePage); // 直接访问主页  
  
// 启动服务器  
app.listen(3000, () => {  
  console.log('Server started on port 3000');  
});```

**1)内置中间件**

使用中间件,设置静态文件的路径及访问;

```javascript
app.use(express.static(path.join(__dirname,"./public")))

(2)自定义中间件

javascript 复制代码
app.use((req,res,next)=>{
    if(req.url=="/"){
        res.end("index")//index.html文件
    }else{
        next()
    }
})
app.use((req,res,next)=>{
    if(req.url=="/list"){
        res.end("list")//list.html文件
        
    }
    else{
        next()
    }
})

app.use((req,res,next)=>{
    if(req.url=="/order"){
        res.end("order")//order.html文件
    }
})

(3)第三方中间件

使用官网资源中的中间件==》》》body-parser

javascript 复制代码
cnpm install body-parser -s

代码:

javascript 复制代码
const bodyParse = require("body-parser");

app.use(express.static(path.join(__dirname, "./public")))
app.use(bodyParse.urlencoded({ extended: false }))

使用post

javascript 复制代码
app.post("/list",(req,res)=>{
    let{username,age}=req.body;

    res.json({
         username,
         age
    })
})

使用get

javascript 复制代码
app.get("/user", (req, res) => {
    let { username, age } = req.body;
    console.log({ username, age });
    res.json({
        username,
        age
    })

})

(4)路由中间件

在这个例子中,logRequest中间件被应用于所有路由,因为我们将它添加为应用程序级别的中间件(使用app.use())。然后,我们定义了一个路由(/)并附加了一个处理程序(homePage)。当有人访问/路由时,他们首先会触发logRequest中间件,然后才会触发homePage处理程序。

javascript 复制代码
const express = require('express');  
const app = express();  
  
// 这是一个简单的中间件函数,用于记录每个请求的URL  
function logRequest(req, res, next) {  
  console.log(`Request URL: ${req.url}`);  
  next(); // 调用下一个中间件或路由处理程序  
}  
  
// 这是一个路由处理程序  
function homePage(req, res) {  
  res.send('Home Page');  
}  
  
// 使用中间件函数  
app.use(logRequest); // 这个中间件将应用于所有路由  
  
// 定义路由并附加处理程序  
app.get('/', homePage);  
  
// 启动服务器  
app.listen(3000, () => {  
  console.log('Server started on port 3000');  
});
相关推荐
黄俊懿19 小时前
【架构师从入门到进阶】第一章:架构设计基础——第二节:架构设计原则
分布式·后端·中间件·架构
御坂10101号19 小时前
JIT 上的 JIT:Elysia JS 的优化实践与争议
开发语言·javascript·网络·性能优化·node.js·express
花果山总钻风3 天前
SQLAlchemy各种排序示例
后端·python·中间件
weixin_421994783 天前
依赖注入与中间件 - ASP.NET Core 核心概念
后端·中间件·asp.net
PD我是你的真爱粉4 天前
RabbitMQRPC与死信队列
后端·python·中间件
曼岛_5 天前
[Java实战]springboot3项目使用宝蓝德中间件 bes-lite-spring-boot-starter 添加安全头
java·安全·中间件
带娃的IT创业者5 天前
专栏系列04(模块1第4篇) 《蓝图系统与中间件帝国:40+个路由模块的组织哲学》
python·中间件·flask·蓝图·blueprint·python蓝图
金刚猿7 天前
02_虚拟机中间件部署_安装 MySQL 服务【创建用户、数据挂载】
数据库·mysql·中间件
萧曵 丶7 天前
主流消息队列(MQ)的核心架构、底层原理
中间件·架构·mq