微服务中基于JWT的安全认证使用示例

在微服务系统中有多种方案来保持用户的状态及安全认证,比如session方案,token方案,本文讨论比较主流的JWT方案的使用示例。

基本的设计方案如下:

 JWT字符串由3部分组成,分别是Header、Payload和Signature,由两个句点符合分割,可以到https://jwt.io网站上进行在线解析。字符串样例如下:

eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzUxMiJ9.eyJleHAiOjE2Nzc5MDc1NjYsInVzZXJJZCI6IjU0MDg2NTM3LTdlYjItNGUyMC1hMWUxLTJlNjc4NGUxNDEyNSIsImVtYWlsIjoidGVzdEBmcmVlY29kZS5jb20ifQ.htjMGp8KBpuarxjCEHNle33btu6jEKqGTfL1YRX9xnmd669NExZDhaUO--8Uv22h4sQQT3jjrBc4p_YOWhfK3Q

这里生成JWT的库主要使用java-jwt,其pom文件引用如下:

<dependency>
	<groupId>com.auth0</groupId>
	<artifactId>java-jwt</artifactId>
	<version>3.6.0</version>
</dependency>

使用HMAC512算法,定义了一个名为userId的Claimÿ

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值