[发明专利]一种基于JWT的可手动撤销的授权方法在审
申请号: | 201911119920.4 | 申请日: | 2019-11-15 |
公开(公告)号: | CN110855672A | 公开(公告)日: | 2020-02-28 |
发明(设计)人: | 司毅 | 申请(专利权)人: | 无锡家校邦网络科技有限公司 |
主分类号: | H04L29/06 | 分类号: | H04L29/06;H04L9/06;H04L9/08;H04L9/32 |
代理公司: | 淮安睿合知识产权代理事务所(普通合伙) 32372 | 代理人: | 赵霎 |
地址: | 214000 江苏省无锡市新吴*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 jwt 手动 撤销 授权 方法 | ||
本发明涉及网络授权技术的运用,具体为一种基于JWT的可手动撤销的授权方法,是一种基于访问令牌的高效、可回收、可即时更新的授权机制;包括用于提供登录凭证验证程序和服务器对访问令牌校验流程;其中用于提供登录凭证验证程序包括如下步骤:1a:根据登录凭证查询用户信息;2a:判断是否能够取得用户信息,若能够取得用户信息则生成令牌ID组装令牌数据;3a:对上述2a中的令牌数据进行数字签名;4a:将令牌信息保存到持久化数据库,并创建访问令牌记录;5a:将令牌设置到X‑Access‑Token响应头并认证结束;6a:对上述2a中判断是否能够取得用户信息,若不能够取得用户信息则直接认证结束。
技术领域
本发明涉及网络授权技术的运用,具体为一种基于JWT的可手动撤销的授权方法。
背景技术
客户端用户权限的授予与鉴定是一个互联网应用所必不可少的功能。主流的认证方式有基于Cookie和Session的认证方式以及基于访问令牌的认证方式。
传统的Web应用在服务器端使用Session存储用户授权信息。这种方式易于实现,客户端几乎不需要做额外的处理,仅需要由服务器在响应头中设置需要在客户端的Cookie中保存的Session ID即可,并且只需在服务器端销毁Session即可实现权限的回收。但是基于Cookie的认证方式存在Web安全问题,容易通过客户端重定向的方式盗用客户端的权限。另外,使用Session存储用户授权信息会消耗服务器的内存空间,难以应对高并发请求。随着移动互联网的高速发展,这一弊端逐渐显现。
因此,如今大多数Web应用实用基于访问令牌的认证方式(具体为JWT,即JSON WebToken)。访问令牌是一个加密的数据,包含了用户的基本信息及令牌的有效截止时间。由于访问令牌本身包含了认证信息(即访问令牌是自解释的),因此不需要占用服务器的内存空间。但是使用访问令牌时有以下问题需要解决:
(1)如何在访问令牌生成后、过期前撤销授权(2)如果在访问令牌生成后,用户的信息发生了变化,那么要如何更新客户端的访问令牌。
发明内容
本发明的目的是为了解决上述技术不足,提供了一种基于JWT的可手动撤销的授权方法,是一种基于访问令牌的高效、可回收、可即时更新的授权机制。
为解决上述技术问题,本发明所采用的技术方案为:一种基于JWT的可手动撤销的授权方法,包括用于提供登录凭证验证程序和服务器对访问令牌校验流程;
其中用于提供登录凭证验证程序包括如下步骤:
1a:根据登录凭证查询用户信息;
2a:判断是否能够取得用户信息,若能够取得用户信息则生成令牌ID组装令牌数据;
3a:对上述2a中的令牌数据进行数字签名;
4a:将令牌信息保存到持久化数据库,并创建访问令牌记录;
5a:将令牌设置到X-Access-Token响应头并认证结束;
6a:对上述2a中判断是否能够取得用户信息,若不能够取得用户信息则直接认证结束;
其中服务器对访问令牌校验流程包括如下步骤:
1b:从Authorization请求头取得令牌,并校验令牌是否有效;
2b:若令牌有效则根据令牌ID取得缓存中的令牌记录,并判断缓存这种是否存在令牌记录;
3b:若缓存中存在令牌记录,则延长缓存记录的生命期;再判断用户信息是否已被更新;
4b:若用户信息已被更新,则查询用户信息重新则查询用户信息重新进行数字签名;
5b:判断是否有权执行此操作,若有权执行此操作则执行操作;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于无锡家校邦网络科技有限公司,未经无锡家校邦网络科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201911119920.4/2.html,转载请声明来源钻瓜专利网。
- 上一篇:鸟巢式多功能哺乳枕
- 下一篇:一种土壤水分管理恒重装置