node-jwks-rsa 使用教程

node-jwks-rsa 使用教程

node-jwks-rsaA library to retrieve RSA public keys from a JWKS (JSON Web Key Set) endpoint.项目地址:https://gitcode.com/gh_mirrors/no/node-jwks-rsa

1、项目介绍

node-jwks-rsa 是一个用于从 JWKS (JSON Web Key Set) 端点检索 RSA 公钥的库。它广泛应用于需要安全地验证 JSON Web Tokens (JWT) 的 Node.js 项目中。该库支持所有当前注册的 JWK 类型和 JWS 算法,确保了高度的安全性和兼容性。

2、项目快速启动

安装

在你的项目目录中运行以下命令进行安装:

npm install --save jwks-rsa

配置客户端

提供一个暴露你的签名密钥的 JWKS 端点:

const jwksClient = require('jwks-rsa');
const client = jwksClient({
  jwksUri: 'https://sandrino.auth0.com/.well-known/jwks.json',
  requestHeaders: {}, // 可选
  timeout: 30000 // 默认为 30s
});

检索密钥

使用 getSigningKey 方法检索与特定 kid 匹配的签名密钥:

const kid = 'RkI5MjI5OUY5ODc1N0Q4QzM0OUYzNkVGMTJDOUEzQkFCOTU3NjE2Rg';
const key = await client.getSigningKey(kid);
const signingKey = key.publicKey || key.rsaPublicKey;

3、应用案例和最佳实践

应用案例

node-jwks-rsa 常用于需要验证 JWT 的 Web 应用和 API 服务中。例如,一个使用 Express 框架的 Node.js 应用可以通过中间件来验证 JWT:

const express = require('express');
const app = express();
const jwt = require('express-jwt');
const jwksRsa = require('jwks-rsa');

const checkJwt = jwt({
  secret: jwksRsa.expressJwtSecret({
    cache: true,
    rateLimit: true,
    jwksRequestsPerMinute: 5,
    jwksUri: 'https://sandrino.auth0.com/.well-known/jwks.json'
  }),
  audience: 'https://api.myapp.com',
  issuer: 'https://sandrino.auth0.com/',
  algorithms: ['RS256']
});

app.get('/protected', checkJwt, (req, res) => {
  res.json({ message: 'This is a protected route' });
});

app.listen(3000, () => {
  console.log('Server is running on port 3000');
});

最佳实践

  • 缓存密钥:启用缓存以减少对 JWKS 端点的请求次数。
  • 速率限制:限制每分钟对 JWKS 端点的请求次数,防止滥用。
  • 安全头:在请求头中添加必要的认证信息,确保请求的安全性。

4、典型生态项目

node-jwks-rsa 通常与以下项目一起使用:

  • express-jwt:用于在 Express 应用中验证 JWT。
  • jsonwebtoken:用于生成和验证 JWT。
  • passport-jwt:用于在 Passport 策略中验证 JWT。

这些项目共同构成了一个强大的身份验证和授权生态系统,适用于各种 Node.js 应用。

node-jwks-rsaA library to retrieve RSA public keys from a JWKS (JSON Web Key Set) endpoint.项目地址:https://gitcode.com/gh_mirrors/no/node-jwks-rsa

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

祁婉菲Flora

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值