nodejs-koa2-mysql-sequelize-jwt

技术栈:nodejs, koa2, mysql, sequelize, jwt

项目数据层和操作层分明

使用koa2框架中间件,参数处理

jwt做权限接口验证

sequelize管理mysql数据库

异步处理async/await

已实现登录注册接口,文章增删改查接口

喜欢或对你有帮助的话请点star✨✨,或有您有更好的建议和意见,请提出来告知我,可以留言issues,可以加我QQ: 841053515, Thanks.

项目地址 点击跳转https://github.com/liangfengbo/nodejs-koa2-mysql-sequelize-jwt.git

一、学习使用

git clone

git clone https://github.com/liangfengbo/nodejs-koa2-mysql-sequelize-jwt.git

1.1.安装

npm install

1.2.需要在config文件下db.js配置本地数据库

const sequelize = new Sequelize('数据库', '数据库用户名', '数据库密码', {})

别忘了创建数据库,黑窗口登录msyql:create database '数据库用户名'

1.3.开启服务

npm start

二、路由说明

// └──routes/index.js文件

const router = new Router({

prefix: '/api/v1'

})

/**

* 用户接口

*/

// 用户注册

router.post('/user', UserController.create);

// 用户登录

router.post('/user/login', UserController.login);

// 获取用户信息

router.get('/user', UserController.getUserInfo);

// 获取用户列表

router.get('/user/list', UserController.getUserList);

// 删除用户

router.delete('/user/:id', UserController.delete);

/**

* 文章接口

*/

// 创建文章

router.post('/article', ArticleController.create);

// 获取文章列表

router.get('/article', ArticleController.getArticleList);

// 获取文章详情

router.get('/article/:id', ArticleController.detail);

// 删除文章

router.delete('/article/:id', ArticleController.delete);

// 更改文章

router.put('/article/:id', ArticleController.update);

三、接口说明(用户接口)

创建用户接口

/user

3.1.请求方式

post

3.2.请求参数

参数说明需求

username用户名必填

password密码必填

3.3.返回数据

{

"code": 200,

"msg": "创建用户成功",

"data": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IkJvYiIsImlkIjozLCJpYXQiOjE1Mjg3NzUzOTMsImV4cCI6MTUyODc3ODk5M30.cnWcgJQF1z7adgKp49AgP4UvpqIXUNjGfjWLMq-rMeA"

}

登录接口

/user/login

3.4.请求方式

post

3.5.请求参数

参数说明需求

username用户名必填

password密码必填

3.6.返回数据

{

"code": 200,

"msg": "登录成功",

"data": {

"id": 3,

"username": "Bob",

"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IkJvYiIsImlkIjozLCJpYXQiOjE1Mjg3NzU0NTIsImV4cCI6MTUyODc3OTA1Mn0.v_B_EXvzYTk7Wz-jl4D8F5n5kn2iah8oht0s6S72Zsc"

}

}

获取用户信息

/user

3.7.请求方式

get

3.8.说明

token 一定要传

Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IuaigeWHpOazomJvIiwiaWQiOjUsImlhdCI6MTUyNzczNjc2NSwiZXhwIjoxNTI3NzQwMzY1fQ.y5w4lEFRf8bpR4fFPNDms1m9WSX9mfQ3fo5dejG7y3A

3.9.返回数据

{

"code": 200,

"msg": "查询成功",

"data": {

"id": 3,

"username": "Bob"

}

}

删除用户接口

/user/:id

3.10.请求方式

delete

3.11.请求参数

参数说明需求

id用户ID必填

3.12.返回数据

{

"code": 200,

"msg": "删除用户成功"

}

四、项目主要文件

4.1.1 schema文件

创建数据库表

4.2.1 modules文件

model层 - 主要处理参数

4.3.1 controllers文件

控制器 - 处理数据库增删改查

4.4.1 router 文件

路由

4.5.1 app.js

入口文件

项目身份验证使用了jwt,就是说登录注册和获取用户信息不用jwt验证,其他接口都需要token验证

比如注册用户接口:在postman软件操作接口,例注册接口:

post 请求

http://localhost:3000/api/v1/createUser?username=梁凤波bo&password=bobo12345

创建成功后返回信息:

{

"code": 200,

"message": "创建成功",

"bean": {

"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IuaigeWHpOazomJvIiwiaWQiOjUsImlhdCI6MTUyNzczNjUzMSwiZXhwIjoxNTI3NzQwMTMxfQ.GAQg-hZm3rDYq70-16sgfNHvD64gmrWSFzQCZQs7bl4"

}

}

注册

post 请求

http://localhost:3000/api/v1/user/login?username=梁凤波bo&password=bobo12345

成功返回信息:

{

"message": "登录成功!",

"data": {

"id": 5,

"username": "梁凤波bo",

"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IuaigeWHpOazomJvIiwiaWQiOjUsImlhdCI6MTUyNzczNjc2NSwiZXhwIjoxNTI3NzQwMzY1fQ.y5w4lEFRf8bpR4fFPNDms1m9WSX9mfQ3fo5dejG7y3A"

},

"code": 200

}

处理jwt验证时候,我添加了方法

app.use(jwt({secret: secret.sign}).unless({path: [/^\/api\/v1\/login/, /^\/api\/v1\/createUser/]}))

登录注册都会返回token信息,除了这两个接口必须要发送header头

在header中加入token

Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IuaigeWHpOazomJvIiwiaWQiOjUsImlhdCI6MTUyNzczNjc2NSwiZXhwIjoxNTI3NzQwMzY1fQ.y5w4lEFRf8bpR4fFPNDms1m9WSX9mfQ3fo5dejG7y3A

才能获取到接口信息,而且token有效期是1个小时就失效。

具体可以看项目主要几个文件代码,一起学习进步,如果你有什么好的建议或意见,或如有错误恳请指导,请留言,谢谢

学习推荐链接:

koa2 实现jwt认证 作者日暮途远_ https://www.jianshu.com/p/176198fbdb35

基于 Egg.js 框架的 Node.js 服务构建之用户管理设计

如果对你学习nodejs有帮助,请给个星星star✨✨谢谢

---------------------

作者:一波万波

来源:CSDN

原文:https://blog.csdn.net/yibowanbo/article/details/80521849

版权声明:本文为博主原创文章,转载请附上博文链接!

koa2 mysql sequelize_[转]使用nodejs-koa2-mysql-sequelize-jwt 实现项目api接口相关推荐

  1. koa2 mysql sequelize_使用nodejs-koa2-mysql-sequelize-jwt 实现项目api接口

    nodejs-koa2-mysql-sequelize-jwt 技术栈:nodejs, koa2, mysql, sequelize, jwt 项目数据层和操作层分明 使用koa2框架中间件,参数处理 ...

  2. php mysql 手机归属地_PHP手机号码归属地查询代码(API接口/mysql)_PHP教程

    文章来介绍一下关于手机号码归属地实现方法,我们可以利用api接口与mysql+php来实例有需要的同学看看. 首先我们介绍使用自己的数据库查询多个手机号码,那还是建议你拥有一个自己的的手机号码数据库. ...

  3. node.js mysql 不退出,mysql - 错误:使用NodeJS在MySQL中调用退出后无法排队查询 - SO中文参考 - www.soinside.com...

    我正在尝试运行此NodeJs代码以在Mysql DB中添加数据:app.post("/taxi",(req,res)=>{ let model=req.body.model; ...

  4. Nodejs连接mysql的增、删、改、查操作

    一,创建数据库 Source Database : my_news_test SET FOREIGN_KEY_CHECKS=0;-- ---------------------------- -- T ...

  5. Nodejs连接mysql并实现增、删、改、查

    文章目录 摘要 一.准备 二.建库并插入5条记录 三.先测试一下环境 1. 首先需要安装nodejs 的mysql包 2.编写nodejs与mysql交互的代码 3.运行结果 四.Node.js结合M ...

  6. 下载nodejs的mysql安装包下载_nodejs安装包下载|nodejs(javascript运行环境) v5.3.0 最新稳定版 - 软件下载 - 绿茶软件园|33LC.com...

    nodejs(javascript运行环境)是款运行在服务器端的javascript.nodejs(javascript运行环境)使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效,Node ...

  7. nodejs操作mysql创建库和表_Nodejs操作MySQL数据库

    如何用nodejs操作MySql数据呢,其实写法还是简单的, 1.开始在你的node项目中 npm install mysql --save 2.在你的新建项目中 引入代码 //引入数据库 var m ...

  8. nodejs连接mysql报connect ECONNREFUSED错误的解决方法

    通过AMH面板安装的mysql,用nodejs连接mysql时候结果报[connect ECONNREFUSED]连接错误. 解决方法:添加socketPath 有些mysql 安装的时候不是mysq ...

  9. NodeJS+Express+mySQL服务端开发详解

    NodeJS+Express+mySQL服务端开发详解 随着NodeJS的发展,现在已经被很多人熟知,NodeJS已经成为了前端开发人员必备的技能.本文不会对NodeJS过多介绍 如果你感兴趣可以访问 ...

  10. nodejs mysql事务处理_关于NodeJs如何使用Mysql模块实现事务处理实例

    本篇文章主要介绍了NodeJs使用Mysql模块实现事务处理 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考.一起跟随小编过来看看吧 依赖模块: 1. mysqlnpm install mysq ...

最新文章

  1. IOS开发UISearchBar失去第一响应者身份后,取消按钮不执行点击事件的问题
  2. php session域名共享,实现多域名下共用一个SESSION
  3. Python 库安装方法:pip安装tar.gz压缩包,pip安装whl文件
  4. c语言万年历闹钟程序,c语言编写的万年历 有平年闰年 有闹钟功能.docx
  5. aria-required属性学习笔记
  6. 微服务为什么离不开spring cloud?
  7. java字节码_好的,每个接触Java字节码的人
  8. unable to verify the first certificate
  9. [转载]使用Response.Filter过滤非法词汇
  10. Java集合类之Collection接口学习
  11. 各种浏览器的cache文件夹
  12. stack(后进先出)
  13. word文档去掉复制过来的背景颜色
  14. echart 热搜词云(字符云)的制作以及遇到颜色不会随即变得bug
  15. docker下安装kong和konga
  16. 在笔记本上安装 linux系统--Ubuntu 20.04(实体机安装而非虚拟机)
  17. 服务器参数知多少 带你一一认识这些参数
  18. bootstrap-table 父子表 联动表 完整例子
  19. 慢性疲劳免疫失调综合症(CFIDS)
  20. fortran教程8:模块和包管理

热门文章

  1. Onlyoffice安装步骤
  2. CoffeeScript 详解
  3. 悲剧收场的梅耶尔给雅虎留下了哪些“遗产”?
  4. PAT | 1082 射击比赛 (20分)【附详解】
  5. (github附源码)毕设微信小程序二手书交易后台PHP微擎
  6. java版超级玛丽游戏
  7. 新语法之CORRESPONDING
  8. 使用Rasterio读取栅格数据
  9. 【RNN经典案例】使用RNN模型构建人名分类器(RNN实战-姓名分类)
  10. 《面试系列篇》——Java这些最基础的知识,你还记得多少?