当前位置: 首页>編程日記>正文

Spring Security 与 OAuth2(资源服务器)

Spring Security 与 OAuth2(资源服务器)

resource-server(资源服务器)

资源服务器

  • 要访问资源服务器受保护的资源需要携带令牌(从授权服务器获得)
  • 客户端往往同时也是一个资源服务器,各个服务之间的通信(访问需要权限的资源)时需携带访问令牌
  • 资源服务器通过 @EnableResourceServer 注解来开启一个 OAuth2AuthenticationProcessingFilter 类型的过滤器
  • 通过继承 ResourceServerConfigurerAdapter 类来配置资源服务器

ResourceServerProperties

  • OAuth2 为资源服务器配置提供了 ResourceServerProperties 类,该类会读取配置文件中对资源服务器得配置信息(如授权服务器公钥访问地址)

ResourceServerSecurityConfigurer 可配置属性

  • tokenServices:ResourceServerTokenServices 类的实例,用来实现令牌业务逻辑服务
  • resourceId:这个资源服务的ID,这个属性是可选的,但是推荐设置并在授权服务中进行验证
  • tokenExtractor 令牌提取器用来提取请求中的令牌
  • 请求匹配器,用来设置需要进行保护的资源路径,默认的情况下是受保护资源服务的全部路径
  • 受保护资源的访问规则,默认的规则是简单的身份验证(plain authenticated)
  • 其他的自定义权限保护规则通过 HttpSecurity 来进行配置

解析令牌方法:

  • 使用 DefaultTokenServices 在资源服务器本地配置令牌存储、解码、解析方式
  • 使用 RemoteTokenServices 资源服务器通过 HTTP 请求来解码令牌,每次都请求授权服务器端点 /oauth/check_token
  • 若授权服务器是 JWT 非对称加密,则需要请求授权服务器的 /oauth/token_key 来获取公钥 key 进行解码

代码案例

令牌解析(JWT 对称加密)

资源服务器和授权服务器不在同一个应用,则需告诉资源服务器令牌如何存储与解析,并与授权服务器使用相同的密钥进行解密

@Configuration
@EnableResourceServer
public class OAuth2ResourceConfig extends ResourceServerConfigurerAdapter{@Beanpublic TokenStore tokenStore() {return new JwtTokenStore(jwtAccessTokenConverter());}//与授权服务器使用共同的密钥进行解析@Beanpublic JwtAccessTokenConverter jwtAccessTokenConverter() {JwtAccessTokenConverter converter = new JwtAccessTokenConverter();converter.setSigningKey("123");return converter;}
}

令牌解析(JWT 非对称加密)

  • 非对称加密需要公钥,可以从本地获取,也可以从授权服务器提供的公钥端点获取
  • 若本地获取不到公钥资源文件 pubkey.txt 则从授权服务器端点获取
@Configuration
@EnableResourceServer
public class OAuth2ResourceConfig extends ResourceServerConfigurerAdapter {@Autowiredprivate ResourceServerProperties resourceServerProperties;@Beanpublic TokenStore tokenStore() {return new JwtTokenStore(jwtAccessTokenConverter());}@Beanpublic JwtAccessTokenConverter jwtAccessTokenConverter() {JwtAccessTokenConverter converter = new JwtAccessTokenConverter();//设置用于解码的非对称加密的公钥converter.setVerifierKey(getPubKey());return converter;}private String getPubKey() {Resource resource = new ClassPathResource("pubkey.txt");try (BufferedReader br = new BufferedReader(new InputStreamReader(resource.getInputStream()))) {System.out.println("本地公钥");return br.lines().collect(Collectors.joining("\n"));} catch (IOException ioe) {return getKeyFromAuthorizationServer();}}private String getKeyFromAuthorizationServer() {ObjectMapper objectMapper = new ObjectMapper();String pubKey = new RestTemplate().getForObject(resourceServerProperties.getJwt().getKeyUri(), String.class);try {Map map = objectMapper.readValue(pubKey, Map.class);System.out.println("联网公钥");return map.get("value").toString();} catch (IOException e) {e.printStackTrace();}return null;}}

令牌解析(通过访问授权服务器解析令牌-适用 JDBC、内存存储)

  • 资源服务器通过访问授权服务器 /oauth/check_token 端点解析令牌需要使用 RemoteTokenServices
  • 并且使用 DefaultAccessTokenConverter 来实现令牌数据的存储
    @Autowiredprivate OAuth2ClientProperties oAuth2ClientProperties;@Autowiredprivate AuthorizationServerProperties authorizationServerProperties;@Beanpublic ResourceServerTokenServices tokenServices() {RemoteTokenServices remoteTokenServices = new RemoteTokenServices();remoteTokenServices.setCheckTokenEndpointUrl(authorizationServerProperties.getCheckTokenAccess());remoteTokenServices.setClientId(oAuth2ClientProperties.getClientId());remoteTokenServices.setClientSecret(oAuth2ClientProperties.getClientSecret());remoteTokenServices.setAccessTokenConverter(accessTokenConverter());return remoteTokenServices;}@Beanpublic AccessTokenConverter accessTokenConverter() {return new DefaultAccessTokenConverter();}
  • 修改配置文件
security:oauth2:client:clientId: resource1clientSecret: secretuserAuthorizationUri: http://localhost:9005/oauth/authorizegrant-type: passwordscope: readaccess-token-uri: http://localhost:9005/oauth/tokenresource:userInfoUri: http://localhost:9005/userauthorization:check-token-access: http://localhost:9005/oauth/check_tokenbasic:enabled: false

 




作者:林塬
链接:https://www.jianshu.com/p/6dd03375224d
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。


https://www.fengoutiyan.com/post/15437.html

相关文章:

  • 资源服务器
  • 云服务器是
  • Spring Authorization Server
  • Spring中依赖注入的四种方式
  • Spring常用的三种注入方式
  • 免费云服务器
  • Spring Security
  • 国内的云服务器
  • 鏡像模式如何設置在哪,圖片鏡像操作
  • 什么軟件可以把圖片鏡像翻轉,C#圖片處理 解決左右鏡像相反(旋轉圖片)
  • 手機照片鏡像翻轉,C#圖像鏡像
  • 視頻鏡像翻轉軟件,python圖片鏡像翻轉_python中鏡像實現方法
  • 什么軟件可以把圖片鏡像翻轉,利用PS實現圖片的鏡像處理
  • 照片鏡像翻轉app,java實現圖片鏡像翻轉
  • 什么軟件可以把圖片鏡像翻轉,python圖片鏡像翻轉_python圖像處理之鏡像實現方法
  • matlab下載,matlab如何鏡像處理圖片,matlab實現圖像鏡像
  • 圖片鏡像翻轉,MATLAB:鏡像圖片
  • 鏡像翻轉圖片的軟件,圖像處理:實現圖片鏡像(基于python)
  • canvas可畫,JavaScript - canvas - 鏡像圖片
  • 圖片鏡像翻轉,UGUI優化:使用鏡像圖片
  • Codeforces,CodeForces 1253C
  • MySQL下載安裝,Mysql ERROR: 1253 解決方法
  • 勝利大逃亡英雄逃亡方案,HDU - 1253 勝利大逃亡 BFS
  • 大一c語言期末考試試題及答案匯總,電大計算機C語言1253,1253《C語言程序設計》電大期末精彩試題及其問題詳解
  • lu求解線性方程組,P1253 [yLOI2018] 扶蘇的問題 (線段樹)
  • c語言程序設計基礎題庫,1253號C語言程序設計試題,2016年1月試卷號1253C語言程序設計A.pdf
  • 信奧賽一本通官網,【信奧賽一本通】1253:抓住那頭牛(詳細代碼)
  • c語言程序設計1253,1253c語言程序設計a(2010年1月)
  • 勝利大逃亡英雄逃亡方案,BFS——1253 勝利大逃亡
  • 直流電壓測量模塊,IM1253B交直流電能計量模塊(艾銳達光電)
  • c語言程序設計第三版課后答案,【渝粵題庫】國家開放大學2021春1253C語言程序設計答案
  • 18轉換為二進制,1253. 將數字轉換為16進制
  • light-emitting diode,LightOJ-1253 Misere Nim
  • masterroyale魔改版,1253 Dungeon Master
  • codeformer官網中文版,codeforces.1253 B
  • c語言程序設計考研真題及答案,2020C語言程序設計1253,1253計算機科學與技術專業C語言程序設計A科目2020年09月國家開 放大學(中央廣播電視大學)
  • c語言程序設計基礎題庫,1253本科2016c語言程序設計試題,1253電大《C語言程序設計A》試題和答案200901
  • 肇事逃逸車輛無法聯系到車主怎么辦,1253尋找肇事司機