eggjs 怎么实现更新用户信息接口去更新个性签名?

简介: eggjs 怎么实现更新用户信息接口去更新个性签名?

1、新建更新用户信息的路由

'use strict';
/**
 * @param {Egg.Application} app - egg application
 */
module.exports = app => {
  const { router, controller, middleware } = app;
  // 传入加密字符串
  const verify_token = middleware.verifyToken(app.config.jwt.secret);
  // 注册路由
  router.post('/api/user/register', controller.user.register);
  // 登录路由
  router.post('/api/user/login', controller.user.login);
  // 测试 token 解析
  router.get('/api/user/token', verify_token, controller.user.getTokenInfo);
  // 获取用户信息
  router.get('/api/user/getUserInfo', verify_token, controller.user.getUserInfo);
  // 修改用户信息
  router.post('/api/user/updateUserInfo', verify_token, controller.user.updateUserInfo);
};


2、实现更新用户 updateUserInfo 接口


  1.    通过 post 请求,在请求体中获取签名字段 signature
  2.    用 app.jwt.verify(token, app.config.jwt.secret),解析出 token 的值
  3.    校验是否 token 可以,需要在鉴权中间件里加返回
  4.    根据用户名,在数据库查找相对应的id操作
  5.    通过 service 方法 updateUserInfo 修改 signature 信息


f837ada15a52411b91cef845f6fcb902.png



/controller/user.js 添加,更新用户信息的方法

// 更新用户信息
  async updateUserInfo() {
    try {
      const { ctx, app } = this;
      // 0、获取用户输入的 signature
      const { signature } = ctx.request.body;
      // 1、获取请求头 authorization 属性,值为 token
      const token = ctx.request.header.authorization;
      // 2、用 app.jwt.verify(token, app.config.jwt.secret),解析出 token 的值
      const decode = await app.jwt.verify(token, app.config.jwt.secret);
      // 3、校验是否 token 可以,需要在鉴权中间件里加返回
      if(!decode) return;
      // 4、根据用户名,在数据库查找相对应的id操作
      const userInfo = await ctx.service.user.getUserByName(decode.username);
      // 5、通过 service 方法 updateUserInfo 修改 signature 信息
      const result = await ctx.service.user.updateUserInfo({
        ...userInfo, signature
      });
      // 返回 token
      ctx.body = {
        status: 200,
        desc: '更新成功',
        data: {
          id: userInfo.id,
          username: userInfo.username,
          signature
        }
      };
    } catch (error) {
      ctx.body = {
        status: 500,
        desc: '更新失败',
        data: null
      }
    }
  }

/service/user.js 添加,更新用户数据库数据的方法

  // 更新用户信息
 async updateUserInfo(params) {
   const { app } = this;
   try {
     // 通过 app.mysql.update 方法更新 user 表, 通过 id 筛选用户
     const result = await app.mysql.update('user', 
       { ...params }, 
       { id: params.id }
     );
     return result;
   } catch(error) {
     console.log(error);
     return null;
   }
 }



3、测试更新用户信息接口


  1. 登录生成 token
  2. 在测试接口请求头带上 token 获取数据
  3. 在测试接口请求体添加个性签名的数据



先新建接口保存


2619931b118049c9a2f760c63c0afc98.png


然后登录拿到 token 运行,修改个性签名信息

03bed0a715be47b4804c477ec5005d18.png







目录
相关文章
|
4天前
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
27 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
若依修改,修改代理线上接口登录后台,若依框架如何使用线上的接口,如何在本地获取网页上的接口
若依修改,修改代理线上接口登录后台,若依框架如何使用线上的接口,如何在本地获取网页上的接口
|
前端开发
前端学习笔记202305学习笔记第二十二天-登录页校验封装和token封装1
前端学习笔记202305学习笔记第二十二天-登录页校验封装和token封装1
81 0
|
前端开发
前端学习笔记202305学习笔记第二十二天-登录页校验封装和token封装2
前端学习笔记202305学习笔记第二十二天-登录页校验封装和token封装2
82 0
|
前端开发
前端学习笔记202305学习笔记第二十一天-vue3.0-发起请求实现添加用户的功能
前端学习笔记202305学习笔记第二十一天-vue3.0-发起请求实现添加用户的功能
77 0
|
前端开发
前端学习笔记202305学习笔记第二十天-vue3.0-请求用户列表的数据
前端学习笔记202305学习笔记第二十天-vue3.0-请求用户列表的数据
78 0
|
缓存 NoSQL 前端开发
若依系统(分离版)后台接口被调时,代码哪里判断了token是否超时?
若依系统(分离版)后台接口被调时,代码哪里判断了token是否超时?
1336 0
|
存储 PHP
php开发实战分析(2):cookie的动态使用(设置、获取、删除、猜你喜欢原理、购物车调用)
php开发实战分析(2):cookie的动态使用(设置、获取、删除、猜你喜欢原理、购物车调用)
244 0
|
前端开发
前端学习笔记202303学习笔记第五天-使用key维护页面的状态
前端学习笔记202303学习笔记第五天-使用key维护页面的状态
102 0
|
前端开发
前端学习笔记202304学习笔记第七天-了解自定义验证函数
前端学习笔记202304学习笔记第七天-了解自定义验证函数
75 0

热门文章

最新文章