学习使用
git clone
安装包
npm install
开启服务
npm start
使用接口(在router/index.js),开启服务后,可以用postman软件测试接口
- const router = new Router({
- prefix: '/api/v1'
- })
-
- /**
- * 用户接口
- */
- // 用户注册
- router.post('/createUser', UserController.createUser);
- // 获取用户信息
- router.get('/userInfo', UserController.getUserName);
- // 用户登录
- router.post('/login', UserController.postLogin);
-
- /**
- * 文章接口
- */
- // 创建文章
- router.post('/article', ArticleController.createArticle);
- // 获取文章列表
- router.get('/article', ArticleController.getArticleList);
- // 获取文章详情
- router.get('/article/:id', ArticleController.getArticleDetail);
- // 删除文章
- router.delete('/article/:id', ArticleController.deleteArticle);
- // 更改文章
- router.put('/article/:id', ArticleController.updateArticle);
-
- /**
- * 导航接口
- */
- // 创建导航
- router.post('/nav', NavController.createNav);
- // 获取导航列表
- router.get('/nav', NavController.getNavlist);
- // 获取导航详情
- router.get('/nav/:id', NavController.getNavDetail);
- // 删除导航
- router.delete('/nav/:id', NavController.deleteNav);
- // 更改导航
- router.put('/nav/:id', NavController.updateNav);
项目主要文件
schema文件
创建数据库表
modules文件
model层 - 主要处理参数
controllers文件
控制器 - 处理数据库增删改查
router 文件
路由
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/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✨✨谢谢