久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

訪問資源服務器控制器內的 Spring OAuth 2 JWT 有效負

Accessing a Spring OAuth 2 JWT payload inside the Resource Server controller?(訪問資源服務器控制器內的 Spring OAuth 2 JWT 有效負載?)
本文介紹了訪問資源服務器控制器內的 Spring OAuth 2 JWT 有效負載?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我正在通過 本教程了解如何設置 Spring Boot oauth與 jwt.它涵蓋了使用 Angular 解碼 JWT 令牌,但我們如何解碼它并訪問資源服務器控制器內的自定義聲明?

I'm going through this tutorial on how to setup spring boot oauth with jwt. It covers decoding the JWT token using Angular, but how do we decode it and get access to custom claims inside the Resource Server controller?

例如,使用 JJWT 可以這樣做(基于這篇文章):

For example with JJWT it can be done like this (Based on this article):

    String subject = "HACKER";
    try {
        Jws jwtClaims = 
            Jwts.parser().setSigningKey(key).parseClaimsJws(jwt);

        subject = claims.getBody().getSubject();

        //OK, we can trust this JWT

    } catch (SignatureException e) {

        //don't trust the JWT!
    }

Spring 有一個 JWTAccessTokenConverter.decode() 方法,但是缺少javadoc,它是受保護的.

And Spring has a JWTAccessTokenConverter.decode() method, but the javadoc is lacking, and it is protected.

推薦答案

這是我在 Spring Boot 中訪問自定義 JWT 聲明的方式:

Here is how I am accessing custom JWT claims in Spring Boot:

1) 讓 Spring 將 JWT 內容復制到 Authentication 中:

1) Get Spring to copy JWT content into Authentication:

@Configuration
@EnableResourceServer
@EnableGlobalMethodSecurity(prePostEnabled = true)
public class SecurityConfig extends ResourceServerConfigurerAdapter{

    @Override
    public void configure(ResourceServerSecurityConfigurer config) {
        config.tokenServices( createTokenServices() );
    }

    @Bean
    public DefaultTokenServices createTokenServices() {
        DefaultTokenServices defaultTokenServices = new DefaultTokenServices();
        defaultTokenServices.setTokenStore( createTokenStore() );
        return defaultTokenServices;
    }

    @Bean
    public TokenStore createTokenStore() {               
        return new JwtTokenStore( createJwtAccessTokenConverter() );
    }

    @Bean
    public JwtAccessTokenConverter createJwtAccessTokenConverter() {
        JwtAccessTokenConverter converter = new JwtAccessTokenConverter();     
        converter.setAccessTokenConverter( new JwtConverter() );
        return converter;
    }

    public static class JwtConverter extends DefaultAccessTokenConverter implements JwtAccessTokenConverterConfigurer {

        @Override
        public void configure(JwtAccessTokenConverter converter) {
            converter.setAccessTokenConverter(this);
        }

        @Override
        public OAuth2Authentication extractAuthentication(Map<String, ?> map) {
            OAuth2Authentication auth = super.extractAuthentication(map);
            auth.setDetails(map); //this will get spring to copy JWT content into Authentication
            return auth;
        }
    }
}

2) 在代碼中的任何位置訪問令牌內容:

2) Access token content anywhere in your code:

Authentication authentication = SecurityContextHolder.getContext().getAuthentication();        
Object details = authentication.getDetails();        
if ( details instanceof OAuth2AuthenticationDetails ){
    OAuth2AuthenticationDetails oAuth2AuthenticationDetails = (OAuth2AuthenticationDetails)details;

    Map<String, Object> decodedDetails = (Map<String, Object>)oAuth2AuthenticationDetails.getDecodedDetails();

    System.out.println( "My custom claim value: " + decodedDetails.get("MyClaim") );
}  

這篇關于訪問資源服務器控制器內的 Spring OAuth 2 JWT 有效負載?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

How to wrap text around components in a JTextPane?(如何在 JTextPane 中的組件周圍環繞文本?)
MyBatis, how to get the auto generated key of an insert? [MySql](MyBatis,如何獲取插入的自動生成密鑰?[MySql])
Inserting to Oracle Nested Table in Java(在 Java 中插入 Oracle 嵌套表)
Java: How to insert CLOB into oracle database(Java:如何將 CLOB 插入 oracle 數據庫)
Why does Spring-data-jdbc not save my Car object?(為什么 Spring-data-jdbc 不保存我的 Car 對象?)
Use threading to process file chunk by chunk(使用線程逐塊處理文件)
主站蜘蛛池模板: 中文字幕国产高清 | 国产精品色 | 国产一级在线观看 | 亚洲一区不卡在线 | 久久国产精品久久久久 | 精品久久av | 亚洲国产精品99久久久久久久久 | 国产一级片一区二区 | 欧美日韩一 | 日韩精品一区二区三区中文字幕 | 精品中文字幕一区二区三区 | a欧美 | h肉视频| 成人综合视频在线观看 | 成人精品免费视频 | 美女一级毛片 | 亚洲精品欧美精品 | 久久伊人一区二区 | 欧美精品一区二区在线观看 | 九九热国产精品视频 | 天天爱天天操 | 国产免费一区二区三区 | 人人人人干 | 免费国产一区 | 中文字幕日韩在线 | 日韩和的一区二区 | 国产高清精品一区二区三区 | 特黄色一级毛片 | 亚洲久草 | www一级片| 超碰91在线 | 99精品久久久 | 久久99精品久久久97夜夜嗨 | 久久久激情视频 | 中文字幕日韩欧美一区二区三区 | 欧美男人天堂 | 欧美在线色 | 精品在线一区 | 丁香一区二区 | 成人啊啊啊 | 国产在线精品一区二区三区 |