使用Spring Security 资源服务器来保护Spring Cloud 微服务
创始人
2025-01-20 21:03:25
0

为了实现平滑过渡,默认的配置肯定不能用了,需要定制化一个JWT解码器。接下来我们一步步来实现它。

分离公私钥

资源服务器只能保存公钥,所以需要从之前的jks文件中导出一个公钥。

keytool-export-aliasfelordcn-keystore-file<导出cer的全路径>

例如:

keytool-export-aliasfelordcn-keystoreD:\keystores\felordcn.jks-filed:\keystores\publickey.cer

把分离的cer公钥文件放到原来jks文件的路径下面,资源服务器不再保存jks

自定义jwt解码器

spring-security-oauth2-jose是Spring Security的jose规范依赖。我将根据该类库来实现自定义的JWT解码器。

/**

*基于Nimbus的jwt解码器,并增加了一些自定义校验策略

*@paramvalidatorthevalidator

*@returnthejwtdecoder

*/

@SneakyThrows

@Bean

publicJwtDecoderjwtDecoder(@Qualifier(“delegatingTokenValidator”)DelegatingOAuth2TokenValidatorvalidator){

CertificateFactorycertificateFactory=CertificateFactory.getInstance(“X.509”);

//从classpath路径读取cer公钥证书来配置解码器

ClassPathResourceresource=newClassPathResource(this.jwtProperties.getCertInfo().getPublicKeyLocation());

Certificatecertificate=certificateFactory.generateCertificate(resource.getInputStream());

PublicKeypublicKey=certificate.getPublicKey();

NimbusJwtDecodernimbusJwtDecoder=NimbusJwtDecoder.withPublicKey((RSAPublicKey)publicKey).build();

nimbusJwtDecoder.setJwtValidator(validator);

returnnimbusJwtDecoder;

}

上面的解码器基于我们的公钥证书,同时我还自定义了一些校验策略。不得不说Nimbus的jwt类库比jjwt要好用的多。

自定义资源服务器配置

相关内容

热门资讯

第九分钟神器!战神辅助发卡官网... 第九分钟神器!战神辅助发卡官网,乐游coc辅助,一直存在有挂(发现有挂)-哔哩哔哩一、战神辅助发卡官...
透视数据!wepoker透视器... 透视数据!wepoker透视器免费,pokemmo手机辅助软件,方式教程(有挂规律)-哔哩哔哩1、操...
第9分钟app!衢州都莱破解器... 第9分钟app!衢州都莱破解器,新天道辅助软件,本来真的是有挂(真实有挂)-哔哩哔哩1、衢州都莱破解...
透视美元局!wepoker游戏... 透视美元局!wepoker游戏下载,hhpoker为什么一直输,手段教程(的确有挂)-哔哩哔哩进入游...
6分钟方法!三哥玩app辅助,... 6分钟方法!三哥玩app辅助,新518互游插件下载,都是存在有挂(今日头条)-哔哩哔哩1、完成新51...
透视安卓版!hhpoker德州... 透视安卓版!hhpoker德州真的假的,如何下载wepoker安装包,大纲教程(详细教程)-哔哩哔哩...
第二分钟技巧!多乐跑辅助,小闲... 第二分钟技巧!多乐跑辅助,小闲川南辅助,好像有挂(详细教程)-哔哩哔哩1、完成小闲川南辅助透视辅助安...
透视黑科技!德州局透视脚本免费... 透视黑科技!德州局透视脚本免费版下载手机版,aapoker能控制牌吗,手段教程(有挂规律)-哔哩哔哩...
1分钟攻略!微信小程序微乐房间... 1分钟攻略!微信小程序微乐房间怎么开挂,佛手在线辅助,果然真的是有挂(有挂详细)-哔哩哔哩1、玩家可...
透视脚本!aapoker万能辅... 透视脚本!aapoker万能辅助器,pokemmo脚本辅助,诀窍教程(有挂细节)-哔哩哔哩1、该软件...