位置: IT常识 - 正文

【Node.js实战】一文带你开发博客项目(API 对接 MySQL)(node.js教程详细)

编辑:rootadmin
【Node.js实战】一文带你开发博客项目(API 对接 MySQL)

推荐整理分享【Node.js实战】一文带你开发博客项目(API 对接 MySQL)(node.js教程详细),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node.js基础入门,node.js gui,node.js gui,node.js基础入门,node.js入门教程,node-js,node js教程,node js教程,内容如对您有帮助,希望把文章链接给更多的朋友!

个人简介

👀个人主页: 前端杂货铺 🙋‍♂️学习方向: 主攻前端方向,也会涉及到服务端 📃个人状态: 在校大学生一枚,已拿多个前端 offer(秋招) 🚀未来打算: 为中国的工业软件事业效力n年 🥇推荐学习:🍍前端面试宝典 🍉Vue2 🍋Vue3 🍓Vue2&Vue3项目实战 🥝Node.js 🌕个人推广:每篇文章最下方都有加入方式,旨在交流学习&资源分享,快加入进来吧

Node.js系列文章目录内容参考链接Node.js(一)初识 Node.jsNode.js(二)Node.js——开发博客项目之接口Node.js(三)Node.js——一文带你开发博客项目(使用假数据处理)Node.js(四)Node.js——开发博客项目之MySQL基础文章目录Node.js系列文章目录一、前言二、Node.js 连接 MySQL三、API 对接 MySQL1、文件目录2、控制器_controller3、路由_router四、各个接口的测试四、写在最后(附源码)一、前言

前面我们已经使用了 假数据去处理路由接口,并学习了开发博客路由相关 MySQL的基础知识。

下面我们就可以 整合改进 这两部分,实现 API 和 MySQL 的对接 工作。

二、Node.js 连接 MySQL

安装 MySQL

npm install mysql

在 src 目录下创建 ./conf/db.js 文件,用于连接数据库的配置

db.js 文件

线上环境与开发环境的配置是不一样的这里写的是一样的,因为项目没有上线// 获取环境参数, process 为 node.js 进程的一些信息const env = process.env.NODE_ENV// 配置let MYSQL_CONF// 开发环境下if (env === 'dev') { MYSQL_CONF = { host: 'localhost', user: 'root', password: '1234abcd', port: '3306', database: 'myblog' }}// 线上环境下if (env === 'production') { MYSQL_CONF = { host: 'localhost', user: 'root', password: '1234abcd', port: '3306', database: 'myblog' }}// 导出共享module.exports = { MYSQL_CONF}

在 src 目录下创建 ./db/mysql.js 文件,用于存放一些数据

mysql.js 文件

引入 mysql 和连接数据库封装 sql 函数,用于统一执行// 引入 MySQLconst mysql = require('mysql')// 引入数据库连接配置const { MYSQL_CONF } = require('../conf/db')// 创建连接对象const con = mysql.createConnection(MYSQL_CONF)// 开始连接con.connect()// 统一执行 sql 的函数function exec(sql) { const promise = new Promise((resolve, reject) => { con.query(sql, (err, result) => { if (err) { reject(err) return } resolve(result) }) }) return promise}// 导出共享module.exports = { exec}三、API 对接 MySQL1、文件目录

2、控制器_controller

blog.js 文件

blog 相关 sql 逻辑返回的是 promise 实例// 导入执行 sql 的相关内容const { exec } = require('../db/mysql')// 获取博客列表(通过作者和关键字)const getList = (author, keyword) => { // 1=1 是为了语法的绝对正确,注意以下 sql 拼接时的空格 let sql = `select * from blogs where 1=1 ` if (author) { sql += `and author='${author}' ` } if (keyword) { sql += `and title like '%${keyword}%' ` } // 以时间的倒序 sql += `order by createtime desc;` // 返回 promise return exec(sql)}// 获取博客详情(通过 id)const getDetail = (id) => { const sql = `select * from blogs where id='${id}'` return exec(sql).then(rows => { // 返回数组的对象 return rows[0] })}// 新建博客 newBlog 若没有,就给它一个空对象const newBlog = (blogData = {}) => { // blogData 是一个博客对象,包含 title content author 属性 const title = blogData.title const content = blogData.content const author = blogData.author const createTime = Date.now() // sql 插入语句 const sql = ` insert into blogs (title, content, createtime, author) values ('${title}', '${content}', '${createTime}', '${author}'); ` return exec(sql).then(insertData => { console.log('insertData is ', insertData) return { id: insertData.insertId } })}// 更新博客(通过 id 更新)const updateBlog = (id, blogData = {}) => { // id 就是要更新博客的 id // blogData 是一个博客对象 包含 title content 属性 const title = blogData.title const content = blogData.content const sql = ` update blogs set title='${title}', content='${content}' where id=${id}` return exec(sql).then(updateData => { // console.log('updateData is ', updateData) // 更新的影响行数大于 0,则返回 true if (updateData.affectedRows > 0) { return true } return false })}// 删除博客(通过 id 删除)const delBlog = (id, author) => { const sql = `delete from blogs where id='${id}' and author='${author}'` return exec(sql).then(delData => { if (delData.affectedRows > 0) { return true } return false })}// 导出共享module.exports = { getList, getDetail, newBlog, updateBlog, delBlog}

user.js 文件

登录相关 sql 逻辑返回的是 promise 实例const { exec } = require('../db/mysql')// 登录(通过用户名和密码)const loginCheck = (username, password) => { const sql = ` select username, realname from users where username='${username}' and password='${password}' ` return exec(sql).then(rows => { return rows[0] || {} })}// 导出共享module.exports = { loginCheck}3、路由_router

blog.js 文件

博客相关路由调用控制器中的方法// 导入博客和用户控制器相关内容const { getList, getDetail, newBlog, updateBlog, delBlog } = require('../controller/blog') // 导入成功和失败的模型const { SuccessModel, ErrorModel } = require('../model/resModel')// blog 相关路由const handleBlogRouter = (req, res) => { const method = req.method // GET/POST const id = req.query.id // 获取 id // 获取博客列表 GET 请求 if (method === 'GET' && req.path === '/api/blog/list') { // 博客的作者,req.query 用在 GET 请求中 const author = req.query.author || '' // 博客的关键字 const keyword = req.query.keyword || '' // 查询的结果 const result = getList(author, keyword) return result.then(listData => { return new SuccessModel(listData) }) } // 获取博客详情 GET 请求 if (method === 'GET' && req.path === '/api/blog/detail') { // 获取博客详情数据 const result = getDetail(id) // 创建并返回成功模型的 promise 实例对象 return result.then(data => { return new SuccessModel(data) }) } // 新建一篇博客 POST 请求 if (method === 'POST' && req.path === '/api/blog/new') { // 假数据,待开发登录时再改成真实数据 req.body.author = 'zhangsan' // req.body 用于获取请求中的数据(用在 POST 请求中) const result = newBlog(req.body) // 创建并返回成功模型的 promise 实例对象 return result.then(data => { return new SuccessModel(data) }) } // 更新一篇博客 if (method === 'POST' && req.path === '/api/blog/update') { // 传递两个参数 id 和 req.body const result = updateBlog(id, req.body) return result.then(val => { if (val) { return new SuccessModel() } else { return new ErrorModel('更新博客失败') } }) } // 删除一篇博客 if (method === 'POST' && req.path === '/api/blog/del') { // 假数据,待开发登录时再改成真实数据 const author = 'zhangsan' const result = delBlog(id, author) return result.then(val => { if (val) { return new SuccessModel() } else { return new ErrorModel('删除博客失败') } }) }}// 导出module.exports = handleBlogRouter

user.js 文件

用户登录相关路由调用控制器中的方法// 导入用户登录内容const { loginCheck } = require('../controller/user')// 导入成功和失败的模板const { SuccessModel, ErrorModel } = require('../model/resModel')// user 路由const handleUserRouter = (req, res) => { const method = req.method // 登录 if (method === 'POST' && req.path === '/api/user/login') { const { username, password } = req.body // 传入两个参数 用户名 密码 const result = loginCheck(username, password) return result.then(data => { if (data.username) { return new SuccessModel() } return new ErrorModel('登录失败') }) }}// 导出共享module.exports = handleUserRouter四、各个接口的测试

查询博客列表

【Node.js实战】一文带你开发博客项目(API 对接 MySQL)(node.js教程详细)

通过关键字查询博客(模糊查询)

通过关键字查询博客(精准查询)

通过id获取博客详情

通过 ApiPost/Postman 工具测试 新建博客

通过 ApiPost/Postman 工具测试 更新博客

通过 ApiPost/Postman 工具测试 删除博客

通过 ApiPost/Postman 工具测试 登录

四、写在最后(附源码)

至此,开发博客的项目(API 对接 MySQL)就完成了。

后续会对该项目进行多次重构【多种框架(express,koa)和数据库(mysql,sequelize,mongodb)】

如果你需要该项目的 源码,请通过本篇文章最下面的方式 加入 进来~~

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

上一篇:此战成硕,我成功上岸西南交通大学了~~~

下一篇:React中useReducer的理解与使用(react usereducer)

  • 小米10怎么恢复出厂设置(小米10怎么恢复照片)

    小米10怎么恢复出厂设置(小米10怎么恢复照片)

  • 手机应用清除数据后果(手机应用清除数据显示灰色)

    手机应用清除数据后果(手机应用清除数据显示灰色)

  • 电脑内存占用多少正常(电脑内存占用多少算高)

    电脑内存占用多少正常(电脑内存占用多少算高)

  • iphone11打字不灵敏(苹果11打字不流畅怎么解决)

    iphone11打字不灵敏(苹果11打字不流畅怎么解决)

  • xr左下角阴影要修么(iphone左下角有阴影)

    xr左下角阴影要修么(iphone左下角有阴影)

  • 回车键发送消息是什么意思(回车键发送消息在哪里设置)

    回车键发送消息是什么意思(回车键发送消息在哪里设置)

  • 光猫千兆口灯闪烁是正常的吗(光猫千兆信号灯闪烁)

    光猫千兆口灯闪烁是正常的吗(光猫千兆信号灯闪烁)

  • 微信显示未读但是找不到(微信标为未读)

    微信显示未读但是找不到(微信标为未读)

  • 怎么注册qq号不用好友辅助(怎么注册qq号不被冻结)

    怎么注册qq号不用好友辅助(怎么注册qq号不被冻结)

  • 数字签名和电子签名的区别(数字签名和电子签字)

    数字签名和电子签名的区别(数字签名和电子签字)

  • iphone耳机能听歌但不能语音(iphone耳机能听歌但不能k歌)

    iphone耳机能听歌但不能语音(iphone耳机能听歌但不能k歌)

  • 录音比特率是什么意思(录音机的比特率)

    录音比特率是什么意思(录音机的比特率)

  • 磁盘有什么用(磁盘有什么作用)

    磁盘有什么用(磁盘有什么作用)

  • 26个字母键属于什么区(26个字母键属于键盘的哪个区)

    26个字母键属于什么区(26个字母键属于键盘的哪个区)

  • qq被屏蔽了还能加好友吗(qq被屏蔽了还能发红包吗)

    qq被屏蔽了还能加好友吗(qq被屏蔽了还能发红包吗)

  • qq加不了群是什么原因(qq加不了群聊)

    qq加不了群是什么原因(qq加不了群聊)

  • 计算机的主频描述(计算机的主频用来描述什么)

    计算机的主频描述(计算机的主频用来描述什么)

  • 华为云备份怎么删除(华为云备份怎么恢复微信聊天记录)

    华为云备份怎么删除(华为云备份怎么恢复微信聊天记录)

  • 毒app支持花呗吗(毒上用花呗有确认收货吗)

    毒app支持花呗吗(毒上用花呗有确认收货吗)

  • 为什么屏幕录制没有声音(为什么屏幕录制出来的视频是黑的)

    为什么屏幕录制没有声音(为什么屏幕录制出来的视频是黑的)

  • 裸机指计算机仅有什么(裸机指计算机仅指什么)

    裸机指计算机仅有什么(裸机指计算机仅指什么)

  • 华为实况模式长曝光在哪里(华为手机实况功能)

    华为实况模式长曝光在哪里(华为手机实况功能)

  • 华为p30pro无线充电多少w(华为p30pro无线充电功率多大)

    华为p30pro无线充电多少w(华为p30pro无线充电功率多大)

  • soul苹果为什么下载不了(soul ios)

    soul苹果为什么下载不了(soul ios)

  • 华为nova3有没有红外线(华为nova3有没有红外)

    华为nova3有没有红外线(华为nova3有没有红外)

  • win10电脑设备管理器在哪里(win10电脑设备管理器在哪)

    win10电脑设备管理器在哪里(win10电脑设备管理器在哪)

  • 使用axis调用WebService,Java WebService调用工具类(客户端调用axis1.4的方式)

    使用axis调用WebService,Java WebService调用工具类(客户端调用axis1.4的方式)

  • 小规模忘了报税怎么办
  • 发票没有纳税人识别号怎么重开
  • 期初存货中固定制造费用
  • 单位注册表从哪里获取
  • 票据背书转让常见的错误
  • 超过标准的职工教育经费
  • 未做工程税费如何计算
  • 生产企业出口退税退的是哪部分的税
  • 接受捐赠的固定资产进项税额可以抵扣吗
  • 最近偷税女星都有谁
  • 损益表和利润表的关系
  • 全资子公司合并抵消
  • 已交税金是什么科目
  • 商家不给发票可以报警吗
  • 股权转让相关手续
  • 工资薪金怎么申报9
  • 会计结算要求
  • 为什么我的win10
  • 小米6桌面图标消失了
  • 汽车空调不制冷的原因有六种
  • 环形链表入口节点
  • g++.exe error
  • h5适配iphonex
  • 货运代理开票
  • 圣保罗大教堂是什么教
  • 本季度企业所得税
  • 增值税专用发票查询系统官方网站
  • 房屋租赁发票怎么入账
  • 工程的直接成本包括哪些
  • 社保挂靠公司收费标准是怎样的
  • 微信小店api
  • bit/ttagapp
  • cvpr2020结果
  • 2022年 change detection遥感图像变化检测 论文附代码
  • vite2.0 vue
  • 加权平均资本结构
  • 房子是固定资产的好处
  • php clone函数
  • 资产负债表日后至财务报告批准报出日之间
  • 个体经营部能抵扣个税吗
  • 期初在产品怎么算
  • mysql字符串索引如何排序
  • 广告公司可以不开发票吗
  • 公允价值变动损益借贷方向增减
  • 递延负债和递延收益
  • 以前年度损益调整怎么做账
  • 生产企业库存商品怎么做分录
  • 印花税每个月都报吗
  • 提前报废固定资产会导致账面价值减少吗
  • 非成品油发票能做进项吗
  • 不动产固定资产的区别
  • 政府拆迁赔款会计上怎样做账
  • 房地产开发企业建造的商品房,在出售前
  • 外贸企业进项税转出怎么申报
  • 红字发票是干什么的
  • 固定资产处置办法
  • 关于小规模纳税人2023年的政策
  • 现金日记账本月合计怎么划线
  • 计入税金及附加借方的内容
  • 计提工资时一定要发票吗
  • 印花税滞纳金怎么处理
  • mysql tmp_table_size和max_heap_table_size大小配置
  • linux操作系统启动
  • RAVMOND.exe - RAVMOND是什么进程.有什么作用
  • 如何快速破局
  • win10无法使用内置管理员账户
  • win7 64位旗舰版电脑中如何让EditPlus软件在保存文件时不生成bak文件?
  • 在Linux上优化Mysql运行环境让你对Mysql更多了解
  • 前端获取http状态码400的返回值实例
  • 所有的未知
  • Androidannotation使用之@Rest获取资源及用户登录验证(一)
  • 一起学写字的宣传文案
  • 原生js import
  • javascript编程软件
  • python列出所有文件名
  • 国家电子税务局云南省电子税务局
  • 无锡税务举报网站
  • 深圳市税务审批中心电话
  • 什么叫发票信息对比
  • 成都市地方税务局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设