Egg.js实战:重构用户登录接口

Egg.js实战:重构用户登录接口

引言

在本篇博客中,我们将使用Egg.js框架来重构用户登录接口。我们将从添加路由开始,然后配置token,接着在service中处理密码,生成token,最后添加controller。我们还将使用Postman进行接口验证。

添加路由

首先,我们需要在router.js中添加路由。这里我们使用router.post方法,将/users/login路径映射到controller.user.login方法。

js 复制代码
module.exports = app => {
  const { router, controller } = app;
  router.post('/users/login', controller.user.login)
};

配置token

接着,我们需要在config.default.js中添加token配置。这里我们使用jsonwebtoken库,设置了secret和expiresIn。

js 复制代码
module.exports = appInfo => {
  // ...其它代码
  config.jwt = {
    secret: 'f2d1c153-39ec-4327-8c86-0d7308ad84f0',
    expiresIn: '1d'
  }

  return {
    ...config,
    ...userConfig,
  };
};

处理密码

service中,我们需要处理密码。因为在model中,我们设置了password为不可选,但是在登录时,我们需要通过email查找到password进行比对,所以我们需要在service中进行处理。

js 复制代码
const Service = require('egg').Service
const jwt = require('jsonwebtoken')

class UserService extends Service {
  // ...其它代码
  findEmail(email) {
    return this.User.findOne({
      email
    }).select('+password')
  }
}

module.exports = UserService

生成token

service/user.js中,我们需要封装token相关的方法。这里我们使用jsonwebtoken库来生成token。

添加controller

最后,我们需要在controller/user.js中添加controller。这里我们首先验证了用户输入的email和password,然后查找用户,如果用户不存在或者密码不正确,我们将抛出错误。如果验证通过,我们将生成token,并返回用户信息和token。

js 复制代码
const Controller = require('egg').Controller
class UserController extends Controller {
  async login() {
    const userBody = this.ctx.request.body
    this.ctx.validate({
      email: { type: 'string' },
      password: { type: 'string' }
    }, userBody)

    const user = await this.service.user.findEmail(userBody.email)
    if (!user) {
      this.ctx.throw(422, '用户未注册')
    }
    if (this.ctx.helper.md5(userBody.password) !== user.password) {
      this.ctx.throw(422, '密码不正确')
    }

    const token = this.service.user.createToken({ user })
    let userinfo = user._doc
    delete userinfo.password
    this.ctx.body = {
      ...userinfo,
      token
    }
  }
}

module.exports = UserController

Postman验证

最后,我们使用Postman进行接口验证,验证结果如下图所示:

总结

以上就是使用Egg.js重构用户登录接口的全部内容。通过这个过程,我们可以看到Egg.js在处理用户登录这样的常见需求时,其强大的功能和灵活性。

相关推荐
明月_清风15 小时前
加密解密系统完全指南:原理剖析与 Go 实践
后端
小江的记录本16 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
不总是16 小时前
Windows 系统 Node.js 免安装版(zip)安装与配置教程(2026 最新)
前端·windows·node.js
冬奇Lab17 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源
ServBay18 小时前
月之暗面 Kimi Code 0.4.0 发布,终端 AI 编码助手全面采用 TypeScript,实现毫秒级启动
后端·aigc·ai编程
小江的记录本18 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
小江的记录本18 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:G1:Region分区、Mixed GC、回收流程、适用场景(高频)(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·spring cloud·面试
欧雷殿19 小时前
从「吸引子引导工程」看我的「一人公司」实践
前端·人工智能·后端
卷无止境20 小时前
用一个电影院售票厅,把 SimPy 的条件事件讲透
后端