【nodejs表单数据的中间件&错误级别的中间件】

一、下载插件

1. 安装 @escook/express-joi 中间件,来实现自动对表单数据进行验证的功能

复制代码
npm install @escook/express-joi

2. 安装 joi 包,为表单中携带的每个数据项,定义验证规则:

joi插件官网: https://joi.dev/

复制代码
npm install joi

3. 新建 /schema/user.js 用户信息验证规则模块,并初始化代码如下:

js 复制代码
const joi = require('joi')
/**
* string() 值必须是字符串
* alphanum() 值只能是包含 a-zA-Z0-9 的字符串
* min(length) 最小长度
* max(length) 最大长度
* required() 值是必填项,不能为 undefined
* pattern(正则表达式) 值必须符合正则表达式的规则
*/

// 用户名的验证规则
const username = joi.string().alphanum().min(1).max(10).required()
// 密码的验证规则
const password = joi
    .string()
    .pattern(/^[\S]{6,12}$/)
    .required()

// 注册和登录表单的验证规则对象
exports.reg_login_schema = {
    // 表示需要对 req.body 中的数据进行验证
    body: {
        username,
        password,
    },
}

4.在请求中使用

router.post('/reguser', expressJoi(reg_login_schema) , user_handler.reguser );

js 复制代码
const express = require("express");
const router = express.Router();// 创建路由对象

// 导入用户路由处理函数对应的模块
const  user_handler = require('../router_handler/user.js')

// 导入验证表单数据的中间件
const expressJoi = require('@escook/express-joi');
// 导入需要的验证规则对象
const { reg_login_schema } = require('../schema/user')

/**
 * 注册新用户
 * 在注册新用户的路由中,声明局部中间件,对当前请求中携带的数据进行验证
 * 数据验证通过后,会把这次请求流转给后面的路由处理函数
 * 数据验证失败后,终止后续代码的执行,并抛出一个全局的 Error 错误,进入全局错误级别中间件中进行
 */
router.post('/reguser', expressJoi(reg_login_schema) , user_handler.reguser );

// 登录
router.post('/login', user_handler.login );

module.exports = router

5.在 app.js的全局错误级别中间件中,捕获验证失败的错误,并把验证失败的结果响应给客户端:

js 复制代码
const express = require('express');// 导入 express 模块
const cors = require('cors');// 导入 cors 中间件


// 创建 express 的服务器实例
const app = express()

// 配置 cors 跨域:将 cors 注册为全局中间件
app.use(cors())


// 一定要在路由之前,封装 res.cc 函数
app.use( ( req ,res ,next ) =>{
    // status 默认值为 1,表示失败的情况
    // err 的值,可能是一个错误对象,也可能是一个错误描述字符串
    res.cc = function (err,status = 1){
        res.send({
            status,
            message: err instanceof Error ? err.message : err
        })
    }

    next();
} )

// 配置解析 application /x-www-form-urlencoded 格式的表单数据的中间件:
app.use(express.urlencoded({ extended: false }))

const userRouter = require('./router/user')
app.use('/api',userRouter)

// 定义错误级别的中间件
const joi = require('@hapi/joi')
app.use(( err ,req , res , next ) => {
    // 数据校验失败
    if (err instanceof joi.ValidationError) return res.cc(err)
    // 未知错误
    res.cc(err) 
})


// 调用 app.listen 方法,指定端口号并启动web服务器
app.listen(3007, function () {
    console.log('api server running at http://127.0.0.1:3007')
})
相关推荐
波波0071 天前
每日一题:中间件是如何工作的?
中间件·.net·面试题
玄同7651 天前
LangChain 1.0 框架全面解析:从架构到实践
人工智能·深度学习·自然语言处理·中间件·架构·langchain·rag
dear_bi_MyOnly2 天前
【多线程——线程状态与安全】
java·开发语言·数据结构·后端·中间件·java-ee·intellij-idea
玄同7653 天前
LangChain v1.0+ 与 FastAPI 中间件深度解析:从概念到实战
人工智能·中间件·langchain·知识图谱·fastapi·知识库·rag
坚持学习前端日记3 天前
容器化中间件的优缺点
java·中间件
BLUcoding3 天前
使用 Docker Compose 安装常用中间件
docker·中间件·容器
沐雪架构师4 天前
LangChain 1.0 内置的Agent中间件详解
中间件·langchain
木子啊4 天前
PHP中间件:ThinkCMF 6.x核心利器解析
开发语言·中间件·php
CTO Plus技术服务中5 天前
大数据、开发环境、中间件、数据库运维开发教程
大数据·数据库·中间件