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

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

1.1.安装

  1. npm install

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

  1. const sequelize = new Sequelize('数据库', '数据库用户名', '数据库密码', {})
  2. 别忘了创建数据库,黑窗口登录msyqlcreate database '数据库用户名'

1.3.开启服务

  1. npm start

二、路由说明

  1. // └──routes/index.js文件
  2. const router = new Router({
  3. prefix: '/api/v1'
  4. })
  5. /**
  6. * 用户接口
  7. */
  8. // 用户注册
  9. router.post('/user', UserController.create);
  10. // 用户登录
  11. router.post('/user/login', UserController.login);
  12. // 获取用户信息
  13. router.get('/user', UserController.getUserInfo);
  14. // 获取用户列表
  15. router.get('/user/list', UserController.getUserList);
  16. // 删除用户
  17. router.delete('/user/:id', UserController.delete);
  18. /**
  19. * 文章接口
  20. */
  21. // 创建文章
  22. router.post('/article', ArticleController.create);
  23. // 获取文章列表
  24. router.get('/article', ArticleController.getArticleList);
  25. // 获取文章详情
  26. router.get('/article/:id', ArticleController.detail);
  27. // 删除文章
  28. router.delete('/article/:id', ArticleController.delete);
  29. // 更改文章
  30. router.put('/article/:id', ArticleController.update);

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

创建用户接口
  1. /user

3.1.请求方式

  1. post

3.2.请求参数

参数 说明 需求
username 用户名 必填
password 密码 必填

3.3.返回数据

  1. {
  2. "code": 200,
  3. "msg": "创建用户成功",
  4. "data": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IkJvYiIsImlkIjozLCJpYXQiOjE1Mjg3NzUzOTMsImV4cCI6MTUyODc3ODk5M30.cnWcgJQF1z7adgKp49AgP4UvpqIXUNjGfjWLMq-rMeA"
  5. }
登录接口
  1. /user/login

3.4.请求方式

  1. post

3.5.请求参数

参数 说明 需求
username 用户名 必填
password 密码 必填

3.6.返回数据

  1. {
  2. "code": 200,
  3. "msg": "登录成功",
  4. "data": {
  5. "id": 3,
  6. "username": "Bob",
  7. "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IkJvYiIsImlkIjozLCJpYXQiOjE1Mjg3NzU0NTIsImV4cCI6MTUyODc3OTA1Mn0.v_B_EXvzYTk7Wz-jl4D8F5n5kn2iah8oht0s6S72Zsc"
  8. }
  9. }
获取用户信息
  1. /user

3.7.请求方式

  1. get

3.8.说明

token 一定要传

  1. Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IuaigeWHpOazomJvIiwiaWQiOjUsImlhdCI6MTUyNzczNjc2NSwiZXhwIjoxNTI3NzQwMzY1fQ.y5w4lEFRf8bpR4fFPNDms1m9WSX9mfQ3fo5dejG7y3A

3.9.返回数据

  1. {
  2. "code": 200,
  3. "msg": "查询成功",
  4. "data": {
  5. "id": 3,
  6. "username": "Bob"
  7. }
  8. }
删除用户接口
  1. /user/:id

3.10.请求方式

  1. delete

3.11.请求参数

参数 说明 需求
id 用户ID 必填

3.12.返回数据

  1. {
  2. "code": 200,
  3. "msg": "删除用户成功"
  4. }

四、项目主要文件

4.1.1schema文件

  1. 创建数据库表

4.2.1modules文件

  1. model - 主要处理参数

4.3.1controllers文件

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

4.4.1router 文件

  1. 路由

4.5.1app.js

  1. 入口文件

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

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

  1. post 请求
  2. http://localhost:3000/api/v1/createUser?username=梁凤波bo&password=bobo12345

创建成功后返回信息:

  1. {
  2. "code": 200,
  3. "message": "创建成功",
  4. "bean": {
  5. "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IuaigeWHpOazomJvIiwiaWQiOjUsImlhdCI6MTUyNzczNjUzMSwiZXhwIjoxNTI3NzQwMTMxfQ.GAQg-hZm3rDYq70-16sgfNHvD64gmrWSFzQCZQs7bl4"
  6. }
  7. }

注册

  1. post 请求
  2. http://localhost:3000/api/v1/user/login?username=梁凤波bo&password=bobo12345

成功返回信息:

  1. {
  2. "message": "登录成功!",
  3. "data": {
  4. "id": 5,
  5. "username": "梁凤波bo",
  6. "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IuaigeWHpOazomJvIiwiaWQiOjUsImlhdCI6MTUyNzczNjc2NSwiZXhwIjoxNTI3NzQwMzY1fQ.y5w4lEFRf8bpR4fFPNDms1m9WSX9mfQ3fo5dejG7y3A"
  7. },
  8. "code": 200
  9. }

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

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

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

在header中加入token

  1. Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6IuaigeWHpOazomJvIiwiaWQiOjUsImlhdCI6MTUyNzczNjc2NSwiZXhwIjoxNTI3NzQwMzY1fQ.y5w4lEFRf8bpR4fFPNDms1m9WSX9mfQ3fo5dejG7y3A

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

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

学习推荐链接:

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

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

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

使用nodejs-koa2-mysql-sequelize-jwt 实现项目api接口的更多相关文章

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

    本文转自:https://blog.csdn.net/yibowanbo/article/details/80521849 nodejs-koa2-mysql-sequelize-jwt技术栈:nod ...

  2. 使用JWT设计SpringBoot项目api接口安全服务

    转载直: 使用JWT设计SpringBoot项目api接口安全服务

  3. 简单实现 nodejs koa2 mysql 增删改查 制作接口

    1.首先 在电脑上安装 nodejs (此处略过) 2.全局安装 koa2 (这里使用的淘宝镜像cnpm,有兴趣的同学可以自行搜索下) cnpm install koa-generator -g 3. ...

  4. 项目API接口鉴权流程总结

    权益需求对接中,公司跟第三方公司合作,有时我们可能作为甲方,提供接口给对方,有时我们也作为乙方,调对方接口,这就需要API使用签名方法(Sign)对接口进行鉴权.每一次请求都需要在请求中包含签名信息, ...

  5. Asp.net Core 项目API接口服务器部署

    Windows server 2008服务器部署: DotNetCore.1.0.0.RC2-WindowsHosting 或者DotNetCore.1.0.5_1.1.2-WindowsHostin ...

  6. 把 nodejs koa2 制作的后台接口 部署到 腾讯云服务器

    我 使用 nodejs koa2框架 制作后端接口, 现在将nodejs koa2 部署到服务器 koa2项目 实现 接口 可以看我的 这篇文章: 简单实现 nodejs koa2 mysql 增删改 ...

  7. koa2+log4js+sequelize搭建的nodejs服务

    主要参考http://www.jianshu.com/p/6b816c609669这篇文章 npm安装使用国内taobao镜像,速度更快些 npm --registry https://registr ...

  8. 分享Node.js + Koa2 + MySQL + Vue.js 实战开发一套完整个人博客项目网站

    这是个什么的项目? 使用 Node.js + Koa2 + MySQL + Vue.js 实战开发一套完整个人博客项目网站. 博客线上地址:www.boblog.com Github地址:https: ...

  9. vue+nodejs+express+mysql 建立一个在线网盘程序

    vue+nodejs+express+mysql 建立一个在线网盘程序 目录 vue+nodejs+express+mysql 建立一个在线网盘程序 第一章 开发环境准备 1.1 开发所用工具简介 1 ...

随机推荐

  1. C-order/Fortran-order(Row-/Column-major order)

    1. row-major / column-major order 无论是行序优先还是列序优先,其实在计算机计算中,指的都是在线性空间(linear storage,如 RAM,也即连续内存存储 co ...

  2. 转载来自朱小厮的博客的NIO相关基础篇

    用户空间以及内核空间概念 我们知道现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32次方).操心系统的核心是内核,独立于普通的应用程序,可以访问受保 ...

  3. spring4+springmvc+hibernate4 demo

    来自 CSDN . 其实下面的更好:加入了maven集成.Spring4 MVC Hibernate4集成 下面也是一篇讲的很详细的文章: hibernate4无法保存数据 而自己遇到的hiberna ...

  4. Archlinux 下Intel + NVIDIA 双显卡3D 游戏配置(dota2@steam)

    下午打了几场dota2 感觉流畅度还算非常不错的,写点东西记录一下.用Archlinux 的一般来说都会用搜索引擎,所以仅仅说下须要注意的地方就可以. 1. steam 自带的OpenGL 库是过时的 ...

  5. 如何直接访问WEB-INF下列文件

    <servlet> <servlet-name>HE</servlet-name> <jsp-file>/WEB-INF/u_member/Login. ...

  6. n阶贝塞尔曲线绘制(C/C#)

    原文:n阶贝塞尔曲线绘制(C/C#) 贝塞尔是很经典的东西,轮子应该有很多的.求n阶贝塞尔曲线用到了 德卡斯特里奥算法(De Casteljau's Algorithm) 需要拷贝代码请直接使用本文最 ...

  7. 谷歌将为 Mac 和 Windows 用户推出新的备份和同步应用

    据报道,谷歌将于 6 月 28 日面向 Mac 和 Windows 用户发布一款新的备份和同步应用(Backup and Sync app). Google 刚刚宣布将推出其备份和同步应用程序,该工具 ...

  8. Redis实现关注关系

    最近使用关系型数据库实现了用户之间的关注,于是思考换一种思路,使用Redis实现用户之间的关注关系. 综合考虑了一下Redis的几种数据结构后,觉得可以用集合实现一下. 假设"我" ...

  9. Android零基础入门第16节:Android用户界面开发概述

    原文:Android零基础入门第16节:Android用户界面开发概述 相信通过前面15期的学习,Android的开发环境已经基本掌握了,如果仍有问题,欢迎到Android零基础入门技术讨论微信群交流 ...

  10. Delphi调用爷爷类的方法(重新构造TMethod的data和code部分,其中Code指向祖父类的方法)

    Delphi通过inherited 可以调用父类的方法,但是没有提供直接调用父类的父类的方法(爷爷类),通过变通的方式实现如下: 假设父类是TFather,爷爷类TGrand,调用爷爷类的Write方 ...