node.js(express.js)+mysql实现新增文章分类功能

表单验证

javascript 复制代码
// 导入定义验证规则的包
// const joi = require("@hapi/joi");
const joi = require("joi");
/**
 * string()值必须是字符串
 * alphanum()值只能包含a-zA-ZO-9的字符串
 * min(length) 最小长度
 * max(length) 大长度
 * required() 值是必填项,不能为 undefined
 * pattern(正则表达式) 值必须符合正则表达式的规则
 */

// 分类表单数据验证
// 定义分类名称和分类别名的效验规则
const name = joi.string().required();
const alias = joi.string().alphanum().required();
//效验规则对象,添加分类
exports.add_cate_schema = {
  body: {
    name,
    alias,
  },
};

定义路由

javascript 复制代码
var express = require("express");
var router = express.Router();
// 1.导入验证数据的中间件
const expressJoi = require("@escook/express-joi");
// 引入封装的获取验证码的方法
var art_handler = require("../controllers/artcate");
const { add_cate_schema } = require("../schema/artcate");
// 获取文章分类的列表
router.get("/cates", art_handler.getArticleClassification);
// 新增文章
router.post(
  "/newArticle",
  expressJoi(add_cate_schema),
  art_handler.newArticleCategory
);
module.exports = router;

实现新增文章分类的功能的函数

javascript 复制代码
// 新增文章
exports.newArticleCategory = (req, res) => {
  // 定义查重的SQL语句
  // 定义查询,分类名称和分类别名,是否被占用的sql语句
  const sql = `select * from ev_article_cate where name=? or alias=?`;
  db.query(sql, [req.body.name, req.body.alias], (err, results) => {
    // 执行sql失败
    if (err) return res.cc(err);
    // 判断分类名称和类别是否被占用
    if (results.length == 2)
      return res.cc("分类名称和类别名称已被占用,请重试");
    if (results.length === 1 && results[0].name === req.body.name)
      return res.cc("分类名称被占用请重试");
    if (results.length === 1 && results[0].alias === req.body.alias)
      return res.cc("类别名称被占用请重试");
    if (
      results.length === 1 &&
      results[0].alias === req.body.alias &&
      results[0].name === req.body.name
    )
      return res.cc("分类名称和类别名称都已被占用,请重试");
    // 新增文章分类
    const sql = `insert into ev_article_cate set ?`;
    db.query(sql, req.body, (err, results) => {
      // sql语句执行失败
      if (err) return res.cc(err);
      // sql语句执行成功,但是影响行数不等于1
      if (results.affectedRows !== 1) return res.cc("新增文章分类失败");
      // 新增文章分类成功
      res.cc("新增文章分类成功!", 0);
    });
  });
};

结果

相关推荐
脑袋大大的26 分钟前
JavaScript 性能优化实战:减少 DOM 操作引发的重排与重绘
开发语言·javascript·性能优化
速易达网络2 小时前
RuoYi、Vue CLI 和 uni-app 结合构建跨端全家桶方案
javascript·vue.js·低代码
耶啵奶膘2 小时前
uniapp+firstUI——上传视频组件fui-upload-video
前端·javascript·uni-app
JoJo_Way2 小时前
LeetCode三数之和-js题解
javascript·算法·leetcode
视频砖家2 小时前
移动端Html5播放器按钮变小的问题解决方法
前端·javascript·viewport功能
墨菲安全5 小时前
NPM组件 betsson 等窃取主机敏感信息
前端·npm·node.js·软件供应链安全·主机信息窃取·npm组件投毒
GISer_Jing5 小时前
Monorepo+Pnpm+Turborepo
前端·javascript·ecmascript
天涯学馆5 小时前
前端开发也能用 WebAssembly?这些场景超实用!
前端·javascript·面试
我在北京coding6 小时前
TypeError: Cannot read properties of undefined (reading ‘queryComponents‘)
前端·javascript·vue.js