Express框架之中间件

◆ 中间件的作用:

中间件就是一堆方法,主要由中间件方法以及请求处理函数组成。可以接收客户端发来的请求、可以对请求做出响应,也可以将请求继续交给下一个中间件继续处理。

app.get('请求路径', '处理函数')   // 接收并处理get请求
app.post('请求路径', '处理函数')  // 接收并处理post请求

在这里插入图片描述

◆ next方法

可以针对同一个请求设置多个中间件,对同一个请求进行多次处理。默认情况下,请求从上到下依次匹配中间件,一旦匹配成功,终止匹配。调用next方法将请求的控制权交给下一个中间件,直到遇到结束请求的中间件。

app.get('/request', (req, res, next) => {
    req.name = "张三";
    next();
});
app.get('/request', (req, res) => {
    res.send(req.name);
});
◆ app.use中间件:

app.use 匹配所有的请求方式,可以直接传入请求处理函数,代表接收所有的请求

app.use((req, res, next) => {
     console.log(req.url);
     next();
 });

app.use 第一个参数也可以传入请求地址,代表不论什么请求方式,只要是这个请求地址就接收这个请求。

app.use('/admin', (req, res, next) => {
    console.log(req.url);
    next();
});
◆ 错误处理中间件:

在程序执行的过程中,不可避免的会出现一些无法预料的错误,比如文件读取失败,数据库连接失败。

错误处理中间件是一个集中处理错误的地方。当程序出现错误时,调用next()方法,并且将错误信息通过参数的形式传递给next()方法,即可触发错误处理中间件。

// 引入express框架
const express = require('express');
const fs = require('fs');
// 创建网站服务器
const app = express();

app.get('/index', (req, res, next) => {
	// throw new Error('程序发生了未知错误')
	fs.readFile('./01.js', 'utf8', (err, result) => {
		if (err != null) {
			next(err)
		}else {
			res.send(result)
		}
	})

	// res.send('程序正常执行')
})

// 错误处理中间
app.use((err, req, res, next) => {
	res.status(500).send(err.message);
})

// 监听端口
app.listen(3000);
console.log('网站服务器启动成功');
◆ 捕获错误:

try catch可以捕获异步函数以及其他同步代码在执行过程中发生的错误,但是不能其他类型的API发生的错误。

// 引入express框架
const express = require('express');
const fs = require('fs');
const promisify = require('util').promisify;
const readFile = promisify(fs.readFile);
// 创建网站服务器
const app = express();

app.get('/index', async (req, res, next) => {
	try {
		await readFile('./aaa.js')
	}catch (ex) {
		next(ex);
	}
})

// 错误处理中间
app.use((err, req, res, next) => {
	res.status(500).send(err.message);
})

// 监听端口
app.listen(3000);
console.log('网站服务器启动成功');
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,针对你的问题:Express 框架中的 session,我可以给你讲解一下。 在 Web 应用中,session 是一种在服务器端存储数据的机制。它允许我们在不同的页面或请求之间共享数据,以实现用户身份验证、购物车、表单填写等功能。 在 Express 框架中,我们可以使用第三方中间件 `express-session` 来实现 session 的功能。具体的实现步骤如下: 1. 安装 `express-session` 中间件: ``` npm install express-session ``` 2. 引入中间件并设置: ```javascript const session = require('express-session'); app.use(session({ secret: 'your secret key', resave: false, saveUninitialized: true })); ``` 这里的 `secret` 参数是用于指定一个秘密字符串,用于加密 session 数据。`resave` 和 `saveUninitialized` 参数分别表示每次请求结束后是否强制保存 session 数据和在没有数据的情况下是否保存一个空的 session 对象。 3. 在路由中使用 session: ```javascript app.get('/login', (req, res) => { req.session.username = 'user1'; res.send('Login success.'); }); app.get('/profile', (req, res) => { const username = req.session.username; if (username) { res.send(`Welcome, ${username}.`); } else { res.send('Please login first.'); } }); ``` 在上面的示例中,我们在 `/login` 路由中设置了 session 的 `username` 属性,然后在 `/profile` 路由中读取了该属性,并根据其值显示不同的信息。 以上就是使用 `express-session` 实现 session 功能的基本步骤。希望能对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值