什么是 Fastify?
Fastify 是 Node.js 服务器框架,它致力于提供快速、低开销和可扩展的 Web 应用程序。Fastify 是一个完全可自定义的框架,它提供了强大的功能和插件生态系统,使开发人员可以构建出性能优化的 Web 服务。
什么是 jsonwebtoken?
jsonwebtoken 是一种用于认证的 JSON Web Token(JWT)库,可以用于 Node.js 和 JavaScript 客户端。JWT 是一种安全的数据传输格式,经过数字签名以保护其完整性,可以验证发送方身份。它由三个部分组成:头部、有效载荷和签名。
头部包含有关标头类型和算法的信息;有效载荷包含用户信息,如 ID、用户名、权限等;签名由使用加密密钥的算法生成。
要在 Fastify 中使用 jsonwebtoken 进行用户认证,您需要遵循以下步骤:
安装 jsonwebtoken 和 fastify-jwt
npm install jsonwebtoken fastify-jwt --save
导入 jsonwebtoken 和 fastify-jwt
const jwt = require('jsonwebtoken'); const fastifyJWT = require('fastify-jwt');
注册 fastify-jwt 插件
fastify.register(fastifyJWT, { secret: 'yoursecretkey' });
必须提供一个 secret 参数,该参数用于加密和解密 token。为了安全起见,建议使用环境变量或从配置文件中获取密钥。
创建路由,并验证 token
fastify.route({ method: 'GET', url: '/private', preHandler: fastify.authenticate, handler: (request, reply) => { reply.send({ message: 'You are authorized!' }); } });
preHandler 参数是 fastify-jwt 中间件,旨在验证 token 有效性。如果 token 无效,则将返回 401 未授权错误。
创建登录路由
-- -------------------- ---- ------- ---------------------- --------- ------ -- - ----- - --------- -------- - - ------------- -- ----- -------- -------- --- -------- ----- ----- - ---------- -------- -- ----------------- ------------ ----- --- ---
用户输入正确的用户名和密码后,应用程序将使用 jsonwebtoken 库为其生成 token 并将其返回给客户端。
示例代码
-- -------------------- ---- ------- ----- ------- - -------------------- ------- ---- --- ----- --- - ------------------------ ----- ---------- - ----------------------- ---------------------------- - ------- --------------- --- ---------------------- --------- ------ -- - ----- - --------- -------- - - ------------- -- ----- -------- -------- --- -------- ----- ----- - ---------- -------- -- ----------------- ------------ ----- --- --- --------------- ------- ------ ---- ----------- ----------- --------------------- -------- --------- ------ -- - ------------ -------- ---- --- ------------ --- - --- -------------------- ----- -------- -- - -- ----- - ----------------------- ---------------- - ------------------------ --------- -- ------------- ---
结论
使用 jsonwebtoken 库可以轻松实现基于 token 的用户认证机制。在 Fastify 中,结合 fastify-jwt 中间件使用,能够更快速地实现高效、可扩展和安全的 Web 应用程序。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/673875db317fbffedf10a8f1