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

结果

相关推荐
masa0103 分钟前
JavaScript--JavaScript基础
开发语言·javascript
她似晚风般温柔7897 小时前
Uniapp + Vue3 + Vite +Uview + Pinia 分商家实现购物车功能(最新附源码保姆级)
开发语言·javascript·uni-app
Jiaberrr8 小时前
前端实战:使用JS和Canvas实现运算图形验证码(uniapp、微信小程序同样可用)
前端·javascript·vue.js·微信小程序·uni-app
everyStudy8 小时前
JS中判断字符串中是否包含指定字符
开发语言·前端·javascript
Ylucius8 小时前
动态语言? 静态语言? ------区别何在?java,js,c,c++,python分给是静态or动态语言?
java·c语言·javascript·c++·python·学习
200不是二百8 小时前
Vuex详解
前端·javascript·vue.js
LvManBa9 小时前
Vue学习记录之三(ref全家桶)
javascript·vue.js·学习
深情废杨杨9 小时前
前端vue-父传子
前端·javascript·vue.js
司篂篂10 小时前
axios二次封装
前端·javascript·vue.js
姚*鸿的博客11 小时前
pinia在vue3中的使用
前端·javascript·vue.js