使用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要好用的多。

自定义资源服务器配置

相关内容

热门资讯

经核实!九江讨赏辅助中至小程序... 经核实!九江讨赏辅助中至小程序(辅助)原来真的有辅助攻略(有挂教学)1、完成九江讨赏辅助中至小程序有...
相较于以往!青龙辅助最新下载(... 相较于以往!青龙辅助最新下载(辅助)总是真的是有辅助插件(详细教程)1、每一步都需要思考,不同水平的...
第三方插件!蜂娱辅助(辅助)切... 第三方插件!蜂娱辅助(辅助)切实确实有辅助挂(有挂讲解)1、金币登录送、破产送、升级送、活动送。详细...
近日!朋朋政和510k辅助器(... 近日!朋朋政和510k辅助器(辅助)都是真的有辅助神器(有挂透视)1、每一步都需要思考,不同水平的挑...
2026版技巧!途游游戏辅助脚... 2026版技巧!途游游戏辅助脚本(辅助)原来是有辅助软件(的确有挂)1、任何途游游戏辅助脚本透视是真...
连日来!圣盛鄂州晃晃辅助(辅助... 连日来!圣盛鄂州晃晃辅助(辅助)总是是真的有辅助软件(有挂方针)1、打开软件启动之后找到中间准星的标...
据权威媒体报道!闲来辅助软件靠... 据权威媒体报道!闲来辅助软件靠谱吗(辅助)一直是有辅助技巧(有挂功能)一、闲来辅助软件靠谱吗可以开透...
做出回应!圣盛鄂州晃晃辅助(辅... 做出回应!圣盛鄂州晃晃辅助(辅助)一直真的是有辅助器(真是有挂);该软件可以轻松地帮助玩家将圣盛鄂州...
有玩家发现!丰城呱呱辅助器(辅... 有玩家发现!丰城呱呱辅助器(辅助)竟然是有辅助工具(有挂存在)1、首先打开丰城呱呱辅助器辅助器下载最...
于此同时!九九联盟辅助神器(辅... 于此同时!九九联盟辅助神器(辅助)确实确实有辅助工具(有挂解密)1)九九联盟辅助神器有没有挂:进一步...