• 使用nodejs-koa2-mysql-sequelize-jwt 实现项目api接口


    nodejs-koa2-mysql 做后端接口

    • 使用nodejs-koa2-mysql后台接口功能
    • 已实现登录注册接口,文章增删改查接口
    • jwt身份验证,中间件,参数处理
    • 使用koa2 + mysql
    • 操作mysql数据库ORM选择sequelize
    • 身份验证使用jwt
    • 异步处理async/await
    • 喜欢或对你有帮助的话请点star✨✨,Thanks.

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

    学习使用

    git clone

    安装包

    npm install

    开启服务

    npm start

    使用接口(在router/index.js),开启服务后,可以用postman软件测试接口

    1. const router = new Router({
    2. prefix: '/api/v1'
    3. })
    4. /**
    5. * 用户接口
    6. */
    7. // 用户注册
    8. router.post('/createUser', UserController.createUser);
    9. // 获取用户信息
    10. router.get('/userInfo', UserController.getUserName);
    11. // 用户登录
    12. router.post('/login', UserController.postLogin);
    13. /**
    14. * 文章接口
    15. */
    16. // 创建文章
    17. router.post('/article', ArticleController.createArticle);
    18. // 获取文章列表
    19. router.get('/article', ArticleController.getArticleList);
    20. // 获取文章详情
    21. router.get('/article/:id', ArticleController.getArticleDetail);
    22. // 删除文章
    23. router.delete('/article/:id', ArticleController.deleteArticle);
    24. // 更改文章
    25. router.put('/article/:id', ArticleController.updateArticle);
    26. /**
    27. * 导航接口
    28. */
    29. // 创建导航
    30. router.post('/nav', NavController.createNav);
    31. // 获取导航列表
    32. router.get('/nav', NavController.getNavlist);
    33. // 获取导航详情
    34. router.get('/nav/:id', NavController.getNavDetail);
    35. // 删除导航
    36. router.delete('/nav/:id', NavController.deleteNav);
    37. // 更改导航
    38. router.put('/nav/:id', NavController.updateNav);

    项目主要文件

    schema文件

    创建数据库表

    modules文件

    model层 - 主要处理参数

    controllers文件

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

    router 文件

    路由

    app.js

    入口文件

    项目身份验证使用了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/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验证时候,我添加了方法

    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 服务构建之用户管理设计

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

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

  • 相关阅读:
    Jetson Nano 部署(2):DeepStream介绍
    猿创征文 第二季| #「笔耕不辍」--生命不息,写作不止#
    7.Nodejs新特性async和await的使用
    基于流量感知的网络切片资源智能分配方法
    8.tomcat优化
    容器安全工具使用指南:保障容器环境安全的利器
    讲讲存档文件的包装设计
    你知道什么是SaaS吗?
    IDEA自定义代码快捷指令
    Java并发编程的艺术笔记-线程中的锁
  • 原文地址:https://blog.csdn.net/m0_72345017/article/details/126734614