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







目录
相关文章
|
设计模式 存储 缓存
微服务实践01--微服务管理11--缓存03--典型缓存架构设计
微服务实践01--微服务管理11--缓存03--典型缓存架构设计
676 0
微服务实践01--微服务管理11--缓存03--典型缓存架构设计
|
存储 缓存 算法
超逼真渲染!虚幻引擎技术大牛解读全局光照系统Lumen(3)
超逼真渲染!虚幻引擎技术大牛解读全局光照系统Lumen
332 0
|
存储 Java 索引
【JAVA】List接口
Array List 的大部分方法是从父类 Collection 和List 继承的,其中add()方法和get()方法分别用于实现元素的存入和取出。下面通过一个案例介绍 Array List 的元素存取。
|
5天前
|
云安全 人工智能 自然语言处理
|
9天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
849 26
|
3天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
435 4