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);
    });
  });
};

结果

相关推荐
wuhen_n8 小时前
LeetCode -- 15. 三数之和(中等)
前端·javascript·算法·leetcode
脾气有点小暴8 小时前
scroll-view分页加载
前端·javascript·uni-app
前端开发爱好者9 小时前
VSCode 重磅更新!要收费了?
前端·javascript·visual studio code
wuhen_n10 小时前
LeetCode -- 1:两数之和(简单)
javascript·算法·leetcode·职场和发展
假装我不帅11 小时前
jquery.nicescroll使用
前端·javascript·jquery
安_11 小时前
js 数组splice跟slice
开发语言·前端·javascript
Maxkim13 小时前
「✍️JS原子笔记 」深入理解JS数据类型检测的4种核心方式
前端·javascript·面试
小高00713 小时前
Elips-Core:轻量级 Node.js Web 框架核心实现
前端·javascript·node.js
前端流一13 小时前
Node.js 原生实现JSON-RPC及长进程双向通信实践
node.js
Aotman_13 小时前
Vue MutationObserver 监听
前端·javascript·vue.js·elementui·前端框架·ecmascript