jwtoauth2與oauth2區別解析

一、介紹

OAuth2是一種授權框架,通常用於提供Web應用程序或服務對持授權的用戶數據的訪問權限。而JWT(JSON Web Token)則是一種可以跨域傳輸的安全令牌,是用於身份驗證的開放標準。

jwtoauth2是基於OAuth2的標準實現。它使用JWT作為標準的令牌格式,與OAuth2一起來對外部客戶端應用程序的訪問進行授權。

二、jwtoauth2與oauth2區別

1、令牌的格式

在OAuth2中,令牌通常是一個字符串,該字符串由一組隨機字符和一個可選的刷新令牌組成,以及一個可選的過期時間。

Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c

而在jwtoauth2中,令牌是一個經過哈希處理的JSON對象。它包含所有必要的數據,如令牌類型、頒發者、頒發時間、過期時間和訪問權限等。

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6Ikpva MTIsImV4cCI6MTUxNjIzOTM4NCwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_ad Qssw5c

2、令牌的加密方式

OAuth2主要使用傳輸層安全性協議(TLS)來加密令牌,而jwtoauth2則使用JSON Web簽名(JWS)或JSON Web加密(JWE)來保證令牌的安全性。

3、令牌的用途

在OAuth2中,令牌主要用於授權訪問受保護資源。在jwtoauth2中,令牌不僅可以用於授權訪問受保護資源,還可以用於設備身份驗證、用戶身份驗證等多種用途。

三、jwtoauth2示例代碼

以下示例介紹了如何通過jwtoauth2在Spring Boot中使用OAuth2。

1、添加依賴項

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-oauth2-jose</artifactId>
    </dependency>

2、配置Spring Security

    @Configuration
    @EnableResourceServer
    public class ResourceServerConfig extends ResourceServerConfigurerAdapter {

        @Override
        public void configure(HttpSecurity http) throws Exception {
            http.authorizeRequests()
                .antMatchers("/api/**").authenticated()
                .and().oauth2ResourceServer().jwt();
        }

        @Bean
        JwtDecoder jwtDecoder() {
            NimbusJwtDecoder jwtDecoder = NimbusJwtDecoder.withJwkSetUri(jwkSetUri).build();
            jwtDecoder.setClaimSetConverter(new UsernameSubClaimAdapter());
            return jwtDecoder;
        }
    }
    
    @Component
    public class UsernameSubClaimAdapter implements Converter<Jwt, Jwt> {

        @Override
        public Jwt convert(Jwt jwt) {
            Map<String, Object> claims = new LinkedHashMap<>(jwt.getClaims());
            Object username = jwt.getClaims().get("sub");
            claims.put("username", username);
            return new Jwt(jwt.getTokenValue(), jwt.getIssuedAt(), jwt.getExpiresAt(), jwt.getHeaders(), claims);
        }

    }

3、配置OAuth2客戶端

    @Configuration
    public class ClientConfig {

        @Bean
        ClientRegistrationRepository clientRegistrationRepository() {
            List<ClientRegistration> registrations = new ArrayList<>();
            registrations.add(gitHubRegistration());
            return new InMemoryClientRegistrationRepository(registrations);
        }

        private ClientRegistration gitHubRegistration() {
            return ClientRegistration.withRegistrationId("github")
                .clientId("github-client-id")
                .clientSecret("github-client-secret")
                .clientAuthenticationMethod(ClientAuthenticationMethod.BASIC)
                .authorizationGrantType(AuthorizationGrantType.AUTHORIZATION_CODE)
                .redirectUri("{baseUrl}/login/oauth2/code/{registrationId}")
                .scope("read:user")
                .authorizationUri("https://github.com/login/oauth/authorize")
                .tokenUri("https://github.com/login/oauth/access_token")
                .userInfoUri("https://api.github.com/user")
                .userNameAttributeName("id")
                .clientName("GitHub")
                .build();
        }

    }

4、啟動應用程序後,可以通過下面的URI進行OAuth2授權:

    http://localhost:8080/oauth2/authorization/github

5、在授權後,可以通過下面的URI獲取受保護資源:

    http://localhost:8080/api/user

四、結論

jwtoauth2是OAuth2協議的補充,它使用JWT代替了OAuth2的令牌格式,更加安全可靠。通過對比,我們可以清晰地認識到它們在令牌格式、令牌加密方式、令牌用途等方面的區別。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/284935.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-22 15:42
下一篇 2024-12-22 15:42

相關推薦

  • Python中new和init的區別

    new和init都是Python中常用的魔法方法,它們分別負責對象的創建和初始化,本文將從多個角度詳細闡述它們的區別。 一、創建對象 new方法是用來創建一個對象的,它是一個類級別…

    編程 2025-04-29
  • Sublime Test與Python的區別

    Sublime Text是一款流行的文本編輯器,而Python是一種廣泛使用的編程語言。雖然Sublime Text可以用於編寫Python代碼,但它們之間有很多不同之處。接下來從…

    編程 2025-04-29
  • Shell腳本與Python腳本的區別

    本文將從多個方面對Shell腳本與Python腳本的區別做詳細的闡述。 一、語法差異 Shell腳本和Python腳本的語法存在明顯差異。 Shell腳本是一種基於字符命令行的語言…

    編程 2025-04-29
  • Python中while語句和for語句的區別

    while語句和for語句是Python中兩種常見的循環語句,它們都可以用於重複執行一段代碼。然而,它們的語法和適用場景有所不同。本文將從多個方面詳細闡述Python中while語…

    編程 2025-04-29
  • Web程序和桌面程序的區別

    Web程序和桌面程序都是進行軟件開發的方式,但是它們之間存在很大的區別。本文將從多角度進行闡述。 一、運行方式 Web程序運行於互聯網上,用戶可以通過使用瀏覽器來訪問它。而桌面程序…

    編程 2025-04-29
  • TensorFlow和Python的區別

    TensorFlow和Python是現如今最受歡迎的機器學習平台和編程語言。雖然兩者都處於機器學習領域的主流陣營,但它們有很多區別。本文將從多個方面對TensorFlow和Pyth…

    編程 2025-04-28
  • 麥語言與Python的區別

    麥語言和Python都是非常受歡迎的編程語言。它們各自有自己的優缺點和適合的應用場景。本文將從語言特性、語法、生態系統等多個方面,對麥語言和Python進行詳細比較和闡述。 一、語…

    編程 2025-04-28
  • MySQL bigint與long的區別

    本文將從數據類型定義、存儲空間、數據範圍、計算效率、應用場景五個方面詳細闡述MySQL bigint與long的區別。 一、數據類型定義 bigint在MySQL中是一種有符號的整…

    編程 2025-04-28
  • Python與C語言的區別和聯繫

    Python與C語言是兩種常用的編程語言,雖然兩者都可以用於編寫軟件程序,但是它們之間有很多不同之處。本文將從多個方面對Python與C語言的區別和聯繫進行詳細的闡述。 一、語法特…

    編程 2025-04-28
  • Python中深拷貝和淺拷貝的區別

    本文將從以下幾個方面對Python中深拷貝和淺拷貝的區別做詳細的闡述,包括:拷貝的含義、變量和對象的區別、淺拷貝的示例、深拷貝的示例、可變對象和不可變對象的區別、嵌套的數據結構以及…

    編程 2025-04-28

發表回復

登錄後才能評論