位置: IT常识 - 正文

【Node.js+koa--后端管理系统】设计动态发布、修改、查询、删除接口(nodejs hook)

编辑:rootadmin
【Node.js+koa--后端管理系统】设计动态发布、修改、查询、删除接口

推荐整理分享【Node.js+koa--后端管理系统】设计动态发布、修改、查询、删除接口(nodejs hook),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node.js import,node.js写后端接口,node.js koa,node:js,node.js写后端接口,nodejs hook,node.js koa,node js 后端,内容如对您有帮助,希望把文章链接给更多的朋友!

🍳作者:贤蛋大眼萌,一名很普通但不想普通的程序媛\color{#FF0000}{贤蛋 大眼萌 ,一名很普通但不想普通的程序媛}贤蛋大眼萌,一名很普通但不想普通的程序媛🤳

🙊语录:多一些不为什么的坚持\color{#0000FF}{多一些不为什么的坚持}多一些不为什么的坚持

📝本文章收录于专栏:Node.js+koa–后端管理系统

💭眼过千遍不如手锤一遍:推荐一款模拟面试,斩获大厂offer,程序员的必备刷题平台−−牛客网\color{#ff7f50}{眼过千遍不如手锤一遍:推荐一款模拟面试,斩获大厂offer,程序员的必备刷题平台--牛客网}眼过千遍不如手锤一遍:推荐一款模拟面试,斩获大厂offer,程序员的必备刷题平台−−牛客网

👉🏻点击跳转刷题网免费注册学习

设计动态发布、修改、查询、删除接口⚙️ 动态内容接口设计思路🍬 发布动态内容接口① 创建新的动态内容表② 定义发布动态内容的接口③ controller层的函数处理④ service 层数据库处理🍿 修改动态内容接口① 定义路由接口② 验证用户是否授权和用户权限③ controller层的函数处理④ service 层数据库处理🍫 查询动态内容接口① 定义路由接口② 定义查询内容的接口(单个)③ 定义查询内容的接口(列表)🧂 删除动态内容接口① 定义路由接口② 验证用户登录和验证用户权限③ Controller和Service中的处理⚙️ 动态内容接口设计思路

🍬 发布动态内容接口① 创建新的动态内容表

建表语句:

CREATE TABLE IF NOT EXISTS `moment`(id INT PRIMARY KEY AUTO_INCREMENT,content VARCHAR(1000) NOT NULL,user_id INT NOT NULL,createAt TIMESTAMP DEFAULT CURRENT_TIMESTAMP,updateAt TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,FOREIGN KEY(user_id) REFERENCES user(id));② 定义发布动态内容的接口

验证用户是否具备权限verifyAuth (//目录:@/middleware/auth_middleware.js)–> 创建动态

//目录:@/router/moment_router.js// 创建动态const Router = require('koa-router')const { create, } = require('../controller/moment_controller')const { verifyAuth,} =require('../middleware/auth_middleware')const momentRouter = new Router({prefix: '/moment'})// 创建动态momentRouter.post('/',verifyAuth,create)③ controller层的函数处理

④ service 层数据库处理

🍿 修改动态内容接口① 定义路由接口

② 验证用户是否授权和用户权限

🎧 PS: 很多的内容都需要验证权限: 修改/删除动态,修改/删除评论

【Node.js+koa--后端管理系统】设计动态发布、修改、查询、删除接口(nodejs hook)

接口:业务接口系统/后端管理系统

一对多:user—>role多对多:role—>menu(删除动态和修改动态)//目录:@/middleware/auth_middleware.js// 验证已登录用户是否具备修改内容权限中间件const verifyPermission = async(ctx,next)=>{ console.log("验证已登录用户是否具备修改内容权限middleware"); // 1.获取用户参数 const [resourceKey ]= Object.keys(ctx.params) const tableName = resourceKey.replace('Id','') const resourceId = ctx.params[resourceKey] const { id } = ctx.user // console.log(momentId,id); // 2.查询是否具备权限 try{ const isPermission = await authServiece.checkResource(tableName,resourceId,id) if(!isPermission) throw new Error() }catch(err){ const error = new Error(errorTypes.UNPERMISSION) return ctx.app.emit('error',error,ctx) } await next()}//目录:@/service/auth_service.js// 数据库查询用户是否存在const connection = require('../app/database')class AuthService { async checkResource (tableName,id,userid){ const statement = `SELECT * FROM ${tableName} WHERE id = ? AND user_id = ?;`; const [result] = await connection.execute(statement,[id,userid]) return result.length === 0? false:true; }}module.exports = new AuthService()③ controller层的函数处理

④ service 层数据库处理

🍫 查询动态内容接口① 定义路由接口//目录:@/router/moment_router.js// 创建动态const Router = require('koa-router')const { create, } = require('../controller/moment_controller')const { verifyAuth,} =require('../middleware/auth_middleware')const momentRouter = new Router({prefix: '/moment'})// 创建动态momentRouter.post('/',verifyAuth,create)// 获取动态信息momentRouter.get('/',list) //获取动态列表momentRouter.get('/:momentId',detail) //获取单个列表② 定义查询内容的接口(单个)

③ 定义查询内容的接口(列表)

最后更新:

🧂 删除动态内容接口① 定义路由接口

② 验证用户登录和验证用户权限

见上面(verifyAuth)和(verifyPermission)

③ Controller和Service中的处理

动态接口设计完成

PS:

求知无坦途,学问无捷径。👣一步一个脚印,你走过的路,每一步都算数。\color{#ff7f50}{一步一个脚印,你走过的路,每一步都算数。}一步一个脚印,你走过的路,每一步都算数。 每一次进步都是对自己努力的肯定。如果读了文章有收获,不如一起来学习,一起进步吧。传送门🚪刷题神器

本文链接地址:https://www.jiuchutong.com/zhishi/300517.html 转载请保留说明!

上一篇:【数据挖掘实战】——家用电器用户行为分析及事件识别(BP神经网络)(数据挖掘技术介绍)

下一篇:如何构建您自己的 ChatGPT:无需代码的 AI(如何构建自己的精神空间)

  • 审计合同需要交税吗
  • 增值税销项税额公式
  • 工业企业应缴纳的税金有哪些
  • 所得税费用是什么要素
  • 车票增值税抵扣如何申报
  • 企业所得税的减免税额和抵免税额区别
  • 增值税发票的红章压到金额没有关系吧
  • 建筑工程企业人才引进可以引进医药行业吗
  • 手工发票可以抵增值税吗
  • 接受的捐赠收入要交税吗
  • 票据贴现利息怎么开发票
  • 税收返还怎么做会计分录
  • 公司为职工在异地买医保
  • 冲减预付账款怎么记账
  • 公司对公银行账户可以注销吗
  • 公司成本票不够交税多少
  • 个人买卖二手房交什么税
  • 小规模纳税人申报纳税详细流程
  • 资源税改革对政治的影响
  • 小规模纳税人增值税超过30万怎么纳税
  • 还有主营业务收入这个科目
  • 企业购买汽车需要缴纳什么税
  • 异地项目预缴个人所得税
  • 无法偿还的借款怎么处理
  • 公对公转账不开票可以吗
  • safedownloader是什么
  • 电子承兑汇票怎么用
  • 一次性收取的房租需要按月纳增值税吗
  • 购货优惠的会计科目
  • 房屋产权置换怎么交税?
  • g++.exe error
  • react img onerror
  • PHP:imagesettile()的用法_GD库图像处理函数
  • 公司以知识产权出资纳税筹划
  • 旅行社的会计
  • elementui级联选择器清空方法
  • 出售土地账务如何处理
  • 固定资产加速折旧最新税收政策2023
  • 数据挖掘论文选题
  • 销售费用的主要类型有哪些
  • 临时工工资无发票可以扣除吗
  • python dict.item()方法遍历字典
  • 电费账务qc
  • 员工报销差旅费现金流量表里放在哪里
  • 出口货物离岸价差异原因说明表在电子税务局的位置
  • sqlserver分布式事务
  • 业务招待费的列支范围
  • 现行印花税税率是多少
  • 交易性金融资产的账务处理
  • 积分兑换商品怎么查快递
  • 特许权使用费计入无形资产吗
  • 外经证如何缴税
  • 怎么对外投资
  • 物业公司收到维修基金会计分录
  • 税负率偏低
  • 收到房租费发票如何做账
  • 收到汇算清缴后怎么做账
  • 私营企业固定资产法律制度
  • 工业营业收入含税吗
  • sql null替换
  • windowsxp电脑开机
  • linux如何关闭selinux
  • win8系统出现自动修复
  • ahci模式下安装win7蓝屏
  • ptssvc.exe - ptssvc是什么进程 有什么用
  • 红石cpu教程
  • 让人吃惊的成语有哪些
  • 图形学实验报告总结
  • opengl中文教程
  • 新闻客户端手机版下载
  • python for key in
  • javascript的数组可以存放任何类型
  • jqueryui easyui
  • js dom操作方法
  • javascript create
  • jquery常用函数
  • 建筑施工及安装单位企业在异地
  • 安徽税务局检验员工资
  • 请问农村自建房彩钢瓦下面修房吊什么顶好
  • 广西税务查询
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设