Koa 中如何使用 koa-jwt 进行 token 验证

阅读时长 6 分钟读完

在前端开发中,安全性是至关重要的,其中 token 鉴权是一种较为常见的验证方法。koa-jwt 是一个基于 Koa 的 token 认证中间件,可以方便快捷地实现 token 验证。

安装并使用 koa-jwt

通过 npm 安装 koa-jwt:

使用 koa-jwt 验证 token 的代码如下:

-- -------------------- ---- -------
----- --- - ---------------
----- --- - -------------------
----- --- - --- ------

------------- ------- --------------- ----------- ----- ----------- ----

------------- --- -- -
  -------- - ------ -------
---

-----------------

上述代码中,jwt 函数是 koa-jwt 的核心,secret 参数是用来对 token 进行签名的秘钥,unless 参数用于排除不需要验证的路由。

验证成功与失败的处理

在使用 koa-jwt 进行 token 验证时,有两种情况:验证成功和验证失败,分别进行不同的处理。

-- -------------------- ---- -------
----- --- - ---------------
----- --- - -------------------
----- --- - --- ------

------------- ----- -- -
  ------ ---------------- -- -
    -- ----------- --- ---- -
      ---------- - ----
      -------- - ------------------
    - ---- -
      ----- ----
    -
  ---
---

------------- ------- --------------- ----------- ----- ----------- ----

------------- --- -- -
  -------- - ------ -------
---

-----------------

上述代码中,使用了 Koa 的错误处理中间件 app.use((ctx, next) => {}); 来处理验证失败的情况。

应用实例

下面通过一个实例来演示如何在 Koa 中使用 koa-jwt 进行 token 验证。

首先,创建一个登录路由:

-- -------------------- ---- -------
------------- --- -- -
  -- -------- --- -------- -- ---------- --- ------- -
    ----- - --------- -------- - - -----------------
    -- --------- --- ------- -- -------- --- -------- -
      ----- ----- - ---------- -------- -- ---------------- - ---------- ---- ---
      -------- - - -------- ------- ----- --
    - ---- -
      ---------- - ----
      -------- - - -------- ---------- --
    -
  -
---

上述代码中,判断请求的链接是否为 /login 以及请求的方法是否为 POST,如果是,则校验用户名和密码是否正确,正确则使用 jwt.sign() 生成 token 返回给前端。

接着,使用 koa-jwt 验证其他路由的 token:

-- -------------------- ---- -------
------------- --- -- -
  -- ---------------------------- -
    ----- ----- ------- --------------- ------- ----- -- -- -
      -- ----
      ----- -------
    ---
  - ---- -
    -------- - ------ -------
  -
---

上述代码中,判断请求的链接是否以 /api 开头。如果是,则使用 koa-jwt 进行验证。在验证成功后,执行相应的 API 逻辑,否则返回 401 错误。

最后,完整代码如下:

-- -------------------- ---- -------
----- --- - ---------------
----- ------ - ----------------------
----- ---------- - --------------------------
----- --- - ------------------------

----- --- - --- ------
----- ------ - --- ---------

----------------------

-- --
------------- --- -- -
  -- -------- --- -------- -- ---------- --- ------- -
    ----- - --------- -------- - - -----------------
    -- --------- --- ------- -- -------- --- -------- -
      ----- ----- - ---------- -------- -- ---------------- - ---------- ---- ---
      -------- - - -------- ------- ----- --
    - ---- -
      ---------- - ----
      -------- - - -------- ---------- --
    -
  -
---

-- ---
------------- --- -- -
  -- ---------------------------- -
    ----- ----- ------- --------------- ------- ----- -- -- -
      -- ----
      ----- -------
    ---
  - ---- -
    -------- - ------ -------
  -
---

-- ------
--------------------------- ----- --- -- -
  -------- - - --------- -------- ---- -- --
---

-------------------------

-----------------

总结

koa-jwt 是 Koa 中的一个常用 token 认证中间件,可以轻松实现 token 验证。在具体使用中,需要注意处理验证成功和验证失败的情况。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/653f0ba37d4982a6eb889d0a

纠错
反馈