博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Koa-jwt 说明文档(机翻润色)
阅读量:6531 次
发布时间:2019-06-24

本文共 3976 字,大约阅读时间需要 13 分钟。

KOA-JWT (机翻润色)

node>=7.6.0

npm v3.2.2

这个模块可以让你在你的KOA应用中通过使用JSON WEB TOKEN(以下简称JWT)认证HTTP请求

这个文档做了一个很好的介绍.

  • 如果你使用KOA版本2.+,同时你有一个低于7.6版本的node. 安装koa-jwt@2

  • 主分支(Koajwt git仓库上的.译者注)上的koa-jwt版本3+使用async/await,所以必须是node 7.6以上

  • 如果你使用koa1,你需要从npm安装koa-jwt@1.这个代码在koa-v1分支上

安装

$ npm install koa-jwt

用例

JWT认证中间件的认证通过使用JWT令牌(token,译者注).如果令牌有效,ctx.state.user(默认情况下)会被设置成解码的JSON对象,以便于在稍后的中间件中进行认证或访问控制.

检索令牌

令牌通常被包产在一个名为Authorization的HTTP头中,但也能通过cookie来进行,但是也可以使用Cookie来提供令牌,只要在opts.cookie选项上设置为包含令牌的cookie的名称.也可以通过opts.getToken选项完成自定义的令牌检索.返回的函数应该匹配以下接口:

/** * 自定义令牌解析器 * @this 传入中间件的CTX对象 * * @param  {object} opts     中间件选项 * @return {String|null}    返回被解析的令牌,如果没有找到则返回null */

令牌解析顺序如下所示.第一个被解析的非空令牌将被用于验证

  • 运行opts.getToken 函数

  • 检查cookies(如果cookies被设置了)

  • 检查承载令牌的认证头(header)

传递密钥

通常你在opts.secret中提供了一个单独的开放密钥,但是另一个替代方案是在一个更靠前的中间件中设置ctx.state.secret,通常是每个请求中.如果这个属性存在,它将用来替换opts.secret中的密钥.

检查销毁密钥

你可以提供一个异步的函数来让koa-jwt检查令牌是否被撤销.这个函数应该被设置再opts.isRevoked属性中.你提供的函数应该匹配以下接口:

/** * 你自定义的检索撤销解析器 * * @param  {object}      ctx     传递给中间件的CTX对象 * @param  {object}      token     令牌 * @param  {object}      user     令牌的内容 * @return {Promise}     如果令牌没有被销毁, Promise必须被解析为false,其他情况下(Promise解析为true或erro)令牌被销毁. */

例子

var Koa = require('koa');var jwt = require('koa-jwt');var app = new Koa();// Custom 401 handling if you don't want to expose koa-jwt errors to usersapp.use(function(ctx, next){  return next().catch((err) => {    if (401 == err.status) {      ctx.status = 401;      ctx.body = 'Protected resource, use Authorization header to get access\n';    } else {      throw err;    }  });});// Unprotected middlewareapp.use(function(ctx, next){  if (ctx.url.match(/^\/public/)) {    ctx.body = 'unprotected\n';  } else {    return next();  }});// Middleware below this line is only reached if JWT token is validapp.use(jwt({ secret: 'shared-secret' }));// Protected middlewareapp.use(function(ctx){  if (ctx.url.match(/^\/api/)) {    ctx.body = 'protected\n';  }});app.listen(3000);

你也可以在某些条件下有条件的运行koa-jwt中间件:

var koa = require('koa');var jwt = require('koa-jwt');var app = new Koa();// Middleware below this line is only reached if JWT token is valid// unless the URL starts with '/public'app.use(jwt({ secret: 'shared-secret' }).unless({ path: [/^\/public/] }));// Unprotected middlewareapp.use(function(ctx, next){  if (ctx.url.match(/^\/public/)) {    ctx.body = 'unprotected\n';  } else {    return next();  }});// Protected middlewareapp.use(function(ctx){  if (ctx.url.match(/^\/api/)) {    ctx.body = 'protected\n';  }});app.listen(3000);

更多关于unless的例子,请点击

即使没有找到认证头,你也可以通过添加一个passthrough选项来保证始终传递到下一个(中间件)

app.use(jwt( { secret: 'shared-secret', passthrough:true }))

通过这个选项,使得下游中间件可以基于ctx.state.user是否设置做出决定

如果你更喜欢使用另外一个ctx key来表示解码数据,只需要传入key属性,如下:

app.use(jwt({ secret: 'shared-secret', key: 'jwtdata' }));

此时解码数据可以通过ctx.state.jwtdata得到(替换掉默认的ctx.state.user)

你同样可以指定audience和/或issuer

app.use(jwt({ secret:   'shared-secret',              audience: 'http://myapi/protected',              issuer:   'http://issuer' }));

如果koa-jwt有设置一个expiration(exp),它将会被检查到.

如果存在tokenkey 选项,并且找到有效的令牌,原始令牌数据可以从随后的中间件中的ctx.state[opts.tokenKey]属性中得到.

这个模块也支持令牌标记为公钥/私钥对. 作为秘钥的替代,你可以通过Buffer指定一个Public key

var publicKey = fs.readFileSync('/path/to/public.pub');app.use(jwt({ secret: publicKey }));

sercret选项是一个函数时,这个函数将会被每个koa-jwt接受到,用于决定哪个密钥会被用于验证JWT

这个方法的签名应该是这样的: (header) => [Promise(secret)], header表示令牌头, 如果想作为支持JWKS的令牌头的实例, 应当包含algkid:算法和密钥ID字段

通过使用 组件,这个选项也可以用于支持JWKS(JSON Web Set),如下:

const { koaJwtSecret } = require('jwks-rsa');app.use(jwt({ secret: koaJwtSecret({                        jwksUri: 'https://sandrino.auth0.com/.well-known/jwks.json',                        cache: true,                        cacheMaxEntries: 5,                        cacheMaxAge: ms('10h') }),              audience: 'http://myapi/protected',              issuer:   'http://issuer' }));

关联模块

jsonwebtoken — JSON Web Token signing and verification

注意koa-v2版本的koa-jwt不再支持从jsonwebtoken中导出sign,verify和decode函数


原文地址:

转载地址:http://awhbo.baihongyu.com/

你可能感兴趣的文章
linux 的网络设置
查看>>
首届“欧亚杯”象翻棋全国团体邀请赛圆满收评!
查看>>
编译tomcat
查看>>
最简单 iText 的 PDF 生成方案(含中文解决方案)HTML 转为 PDF
查看>>
MySql中is NULL、ISNULL()和IFNULL()运行速度的比较
查看>>
关于unichar字符串的初始化
查看>>
oracle-xe手工创建数据库
查看>>
Cisco交换机 链路聚合
查看>>
我的友情链接
查看>>
UG中卸载被占用的DLL
查看>>
eclipse 设置注释模板详解,与导入模板方法介绍总结
查看>>
Cocos2d-x3.2 文字显示
查看>>
估计下星期就能考科目二了
查看>>
轻松实现localStorage本地存储和本地数组存储
查看>>
mongodb group
查看>>
python+selenium自动化测试(二)
查看>>
(笔记 - 纯手敲)Spring的IOC和AOP 含GIT地址
查看>>
7-设计模式介绍
查看>>
让运维更高效:关于ECS系统事件
查看>>
J2EE分布式框架--单点登录集成方案
查看>>