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

结果

相关推荐
大怪v5 小时前
【搞发🌸活】不信书上那套理论!亲测Javascript能卡浏览器Reader一辈子~
javascript·html·浏览器
西陵5 小时前
Nx带来极致的前端开发体验——任务缓存
前端·javascript·架构
Panda__Panda5 小时前
docker项目打包演示项目(数字排序服务)
运维·javascript·python·docker·容器·c#
10年前端老司机6 小时前
Promise 常见面试题(持续更新中)
前端·javascript
WebDesign_Mu9 小时前
为了庆祝2025英雄联盟全球总决赛开启,我用HTML+CSS+JS制作了LOL官方网站
javascript·css·html
噢,我明白了9 小时前
前端js 常见算法面试题目详解
前端·javascript·算法
学编程的小虎9 小时前
用 Python + Vue3 打造超炫酷音乐播放器:网易云歌单爬取 + Three.js 波形可视化
开发语言·javascript·python
做好一个小前端10 小时前
后端接口获取到csv格式内容并导出,拒绝乱码
前端·javascript·html
小菜摸鱼10 小时前
Node.js + vue3 大文件-切片上传全流程(视频文件)
前端·node.js
勤奋菲菲11 小时前
Vue3+Three.js:requestAnimationFrame的详细介绍
开发语言·javascript·three.js·前端可视化