Koa2使用RSA256+jsonwebtoken的实现JWT验证

2024-04-11 10:48

本文主要是介绍Koa2使用RSA256+jsonwebtoken的实现JWT验证,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Koa初体验之RSA256+jsonwebtoken的JWT

  • 项目介绍
  • 项目开始
    • 1.安装依赖
    • 2.获取RSA公钥和私钥
  • 代码实现
    • 1.设置登录的路由
    • 2.Controller层SessionsController.js
    • 3.入口文件引入(app.js)
  • 测试登录接口
    • 1.插件测试登录接口,返回token
    • 2.测试其他接口加上token访问

项目介绍

使用RSA256加密实现jwt鉴权最终获取token

项目开始

1.安装依赖

npm install jsonwebtoken

2.获取RSA公钥和私钥

(因系统不同命令有所不同 ,我这边是mac栗子)

openssl
genrsa -out rsa_private_key.pem 1024
pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt
rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem

完成后生成两个文件(rsa_private_key.pem 与 rsa_public_key.pem)
当然这块也可以修改文件名,我修改成了我喜欢的 ,并统一放到了文件夹下,如图所示:
在这里插入图片描述

代码实现

1.设置登录的路由

    koa.use(koaRoute.post('/sessions', controller.post.bind(controller)))

2.Controller层SessionsController.js

//登录post接口
post (ctx) {//首先判断headers不能为空if (ctx.headers.authorization === undefined || ctx.headers.authorization === null || ctx.headers.authorization === '') {ctx.throw(400, 'Authorization header must be provided!')} else {return this._handleAuthorization(ctx)}}_handleAuthorization (ctx) {const [type] = ctx.headers.authorization.split(' ')if (type.toLowerCase() === 'basic') {return this._handleBasicAuthentication(ctx)} else {ctx.throw(400, 'Invalid authentication type!')}}_handleBasicAuthentication (ctx) {const [, base64String] = ctx.headers.authorization.split(' ')
console.log(base64String)const [username, password] = Buffer.from(base64String, 'base64').toString().split(':')console.log(username + password)return this.getUserByCredentials(username, password).then(user => this._handleUser(ctx, user)).then(jwt => this._respondWithJwt(ctx, jwt))}async getUserByCredentials (username, password) {//密码加密const passwordHash = crypto.createHash('sha256').update(password).digest('hex')console.log(passwordHash)const user = await this._getUserByUsername(username)console.log(user)if (user === null) {return null} else {if (user.passwordHash === passwordHash) {return user} else {return null}}}_getUserByUsername (username) {//查询user表用户名和传入的用户名是否一样return this._User.findOne({where: { userName: username }})}_handleUser (ctx, user) {if (user === null) {ctx.throw(400, 'Invalid user!')} else {const payload = {usr: user.id,role: user.role,name: user.name}console.log(payload)return this._generateJwt(payload)}}// jwt.sign(payload, secretOrPrivateKey, [options, callback])
//   第一个是token载体,放一些需要存放在token里的内容,我这里希望token传递userId,role,name
//   第二个是密钥,可以简单的输入string作为密钥,也可以采用加密算法,例如我现在用的RSA256
//   第三个是option,因为jsonwebtoken加密方式默认是RS256,所以如果用其他加密方式需要在option的algorithm中进行申明,以及其他一些参数_generateJwt (payload) {const minutes = 432000const privateKey = fs.readFileSync('rsaKeys/jwtRS256.key')const options = { algorithm: 'RS256', expiresIn: minutes * 60 }return jwt.sign(payload, privateKey, options)}_respondWithJwt (ctx, jwt) {ctx.status = 201ctx.body = jwtreturn ctx}
}

3.入口文件引入(app.js)

const jwt = require('koa-jwt')
const fs = require("fs")
const publicKey = fs.readFileSync('./rsaKeys/jwtRS256.key.pub')//引用公钥
app.use(jwt({secret: publicKey,key:'token'
}).unless({path: ['/sessions']
}));

测试登录接口

1.插件测试登录接口,返回token

我这里用的是谷歌自带的插件测试接口
在这里插入图片描述
headers 里Authorization输入登录的用户名密码
在这里插入图片描述
设置这里就结束里 触发send按钮 就返回得到token
在这里插入图片描述

2.测试其他接口加上token访问

不带token,接口返回结果如图(401)
在这里插入图片描述
带token接口返回结果如图
在这里插入图片描述

这篇关于Koa2使用RSA256+jsonwebtoken的实现JWT验证的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/893861

相关文章

Rust中的注释使用解读

《Rust中的注释使用解读》本文介绍了Rust中的行注释、块注释和文档注释的使用方法,通过示例展示了如何在实际代码中应用这些注释,以提高代码的可读性和可维护性... 目录Rust 中的注释使用指南1. 行注释示例:行注释2. 块注释示例:块注释3. 文档注释示例:文档注释4. 综合示例总结Rust 中的注释

C# string转unicode字符的实现

《C#string转unicode字符的实现》本文主要介绍了C#string转unicode字符的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录1. 获取字符串中每个字符的 Unicode 值示例代码:输出:2. 将 Unicode 值格式化

python安装whl包并解决依赖关系的实现

《python安装whl包并解决依赖关系的实现》本文主要介绍了python安装whl包并解决依赖关系的实现,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录一、什么是whl文件?二、我们为什么需要使用whl文件来安装python库?三、我们应该去哪儿下

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi

Java中将异步调用转为同步的五种实现方法

《Java中将异步调用转为同步的五种实现方法》本文介绍了将异步调用转为同步阻塞模式的五种方法:wait/notify、ReentrantLock+Condition、Future、CountDownL... 目录异步与同步的核心区别方法一:使用wait/notify + synchronized代码示例关键

Linux使用cut进行文本提取的操作方法

《Linux使用cut进行文本提取的操作方法》Linux中的cut命令是一个命令行实用程序,用于从文件或标准输入中提取文本行的部分,本文给大家介绍了Linux使用cut进行文本提取的操作方法,文中有详... 目录简介基础语法常用选项范围选择示例用法-f:字段选择-d:分隔符-c:字符选择-b:字节选择--c

Nginx实现动态封禁IP的步骤指南

《Nginx实现动态封禁IP的步骤指南》在日常的生产环境中,网站可能会遭遇恶意请求、DDoS攻击或其他有害的访问行为,为了应对这些情况,动态封禁IP是一项十分重要的安全策略,本篇博客将介绍如何通过NG... 目录1、简述2、实现方式3、使用 fail2ban 动态封禁3.1 安装 fail2ban3.2 配

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

Java中实现订单超时自动取消功能(最新推荐)

《Java中实现订单超时自动取消功能(最新推荐)》本文介绍了Java中实现订单超时自动取消功能的几种方法,包括定时任务、JDK延迟队列、Redis过期监听、Redisson分布式延迟队列、Rocket... 目录1、定时任务2、JDK延迟队列 DelayQueue(1)定义实现Delayed接口的实体类 (

使用Go语言开发一个命令行文件管理工具

《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安