主頁 > 後端開發 > SpringSecurity:OAuth2 Client 結合GitHub授權案例(特簡單版)

SpringSecurity:OAuth2 Client 結合GitHub授權案例(特簡單版)

2023-05-09 07:48:16 後端開發

3)OAuth2 Client 結合GitHub授權案例

本隨筆說明:這僅作為OAuth2 Client初次使用的案例,所以寫得很簡單,有許多的不足之處,

OAuth2 Client(OAuth2客戶端)是指使用OAuth2協議與授權服務器進行通信并獲取訪問令牌的應用程式或服務,OAuth2客戶端代表最終用戶(資源擁有者)向授權服務器請求授權,并使用授權后的訪問令牌來訪問受保護的資源服務器,

OAuth2客戶端的主要任務是與授權服務器進行身份驗證和授權流程,以獲取訪問令牌,這樣,它可以使用該令牌來向資源服務器發出請求,獲取和操作受保護的資源,

OAuth2客戶端通常包含以下功能和組件:

  1. 客戶端憑據(Client Credentials):OAuth2客戶端必須擁有一個唯一的客戶端憑據,包括客戶端ID和客戶端密鑰(或密碼),這些憑據用于在與授權服務器進行通信時進行身份驗證和授權,

  2. 授權請求:OAuth2客戶端向授權服務器發送授權請求,包括請求的權限范圍和重定向URL,它會提供自己的客戶端憑據以進行身份驗證,

  3. 授權回呼處理:OAuth2客戶端需要能夠接收和處理來自授權服務器的授權回呼,這是授權服務器將授權碼或訪問令牌傳遞回客戶端的方式,

  4. 訪問令牌的管理:OAuth2客戶端負責管理訪問令牌的獲取、重繪和失效,它應該能夠安全地存盤和使用

3.1 GitHub設定

官方檔案:https://docs.github.com/en/apps/oauth-apps/building-oauth-apps/creating-an-oauth-app

  1. 點擊自己頭像/進入Settings/ 進入Developer settings(左邊導航欄最下面)/ 進入OAuth Apps;然后注冊新應用程式

  2. 注冊新應用程式

    第一步:

    值得注意的是,如果回呼地址不是/login/oauth2/code/*,僅僅是回呼失敗,但是授權會成功,其次就是在spring security中/login/oauth2/code是固定的,而/github是自己指定的,即最后一個是動態的,

    從spring security原始碼中可以看出,回呼地址的固定寫法:

    public class OAuth2LoginAuthenticationFilter extends AbstractAuthenticationProcessingFilter {
        public static final String DEFAULT_FILTER_PROCESSES_URI = "/login/oauth2/code/*";
        private static final String AUTHORIZATION_REQUEST_NOT_FOUND_ERROR_CODE = "authorization_request_not_found";
        private static final String CLIENT_REGISTRATION_NOT_FOUND_ERROR_CODE = "client_registration_not_found";
        private ClientRegistrationRepository clientRegistrationRepository;
        private OAuth2AuthorizedClientRepository authorizedClientRepository;
        private AuthorizationRequestRepository<OAuth2AuthorizationRequest> authorizationRequestRepository;
        private Converter<OAuth2LoginAuthenticationToken, OAuth2AuthenticationToken> authenticationResultConverter;
    
        public OAuth2LoginAuthenticationFilter(ClientRegistrationRepository clientRegistrationRepository, OAuth2AuthorizedClientService authorizedClientService) {
            this(clientRegistrationRepository, authorizedClientService, "/login/oauth2/code/*");
        }
        //省略.....
    }    
    

    第二步:點擊Register application后就會跳轉到如下界面,這時可以創建密鑰(必須)和上傳應用logo(非必須)

    創建密鑰時需要輸入密碼,得到密鑰后請妥善保存,更新資訊后密鑰就不再顯示

    在更新前可以將ClientIDClient secrets以及 回呼URL 保存一下,等下會用到

3.2 開始編碼

創建一個基本的springboot專案,我這里的spring boot版本是:2.7.11,所以spring security的版本是5.7以上的,可能存在語法差異

  1. spring security和oauth2 client的maven依賴

    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-test</artifactId>
        <scope>test</scope>
    </dependency>
    <!--oauth2-client-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-oauth2-client</artifactId>
    </dependency>
    
  2. yml組態檔

    spring.security.oauth2.client.registration是固定寫法,會有提示,而后面的為自定義內容,不會有提示

    server:
      port: 8080
    
    spring:
      security:
        oauth2:
          client:
            registration:
              github:
                client-id: Client ID # 自己的客戶端ID
                client-secret: Client secrets # 自己的密鑰
                redirect-uri: 回呼URL # 必須和GitHub上填的回呼地址一致
    
    
  3. SpringSecurity組態檔

    .oauth2Login()使用oauth2登錄認證

    package com.yang.springsecurityoauthclient01.config;
    
    //省略導包
    
    @Configuration
    @EnableWebSecurity
    @EnableGlobalMethodSecurity(prePostEnabled = true,securedEnabled = true,jsr250Enabled = true)
    public class WebSecurityConfig {
    
        @Bean
        SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
            return http.authorizeRequests()
                    .anyRequest().authenticated()
                    .and()
                    .oauth2Login()  //使用oauth2認證 (需要在組態檔中配置服務,否則可能會啟動失敗 )
                    .and()
                    .csrf().disable()
                    .build();
        }
    }
    
    
  4. controller 控制層撰寫

    package com.yang.springsecurityoauthclient01.controller;
    
    //省略導包
    
    @RestController
    public class HelloController {
    
        @GetMapping("/index")
        public String index(){
            return "主頁~~~";
        }
        
        /**
         * @return GitHub的授權資訊
         */
        @GetMapping("/hello")
        public DefaultOAuth2User hello(){
            Authentication authentication = SecurityContextHolder.getContext().getAuthentication();
            return (DefaultOAuth2User) authentication.getPrincipal();
        }
    }
    
    
  5. 最終結果

    訪問http://localhost:8080/index,點擊GitHub進行授權驗證

    授權Authorize

    訪問http://localhost:8080/hello得到授權資訊:

  6. 撤銷用戶授權

    撤銷授權后重啟程式,之前的用戶就需要進行重新進行授權了,

最后最后需要注意的是,同一個賬號在短時間內別試得太多,不然會出現如下情況,解決辦法也很簡單,等就是了~~~

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/551906.html

標籤:其他

上一篇:原來Spring能注入集合和Map的computeIfAbsent是這么好用!

下一篇:返回列表

標籤雲
其他(158629) Python(38123) JavaScript(25405) Java(18024) C(15222) 區塊鏈(8262) C#(7972) AI(7469) 爪哇(7425) MySQL(7171) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5871) 数组(5741) R(5409) Linux(5336) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4567) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2432) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1965) Web開發(1951) HtmlCss(1932) python-3.x(1918) 弹簧靴(1913) C++(1912) xml(1889) PostgreSQL(1874) .NETCore(1857) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • SpringSecurity:OAuth2 Client 結合GitHub授權案例(特簡單版)

    3)OAuth2 Client 結合GitHub授權案例 本隨筆說明:這僅作為OAuth2 Client初次使用的案例,所以寫得很簡單,有許多的不足之處。 OAuth2 Client(OAuth2客戶端)是指使用OAuth2協議與授權服務器進行通信并獲取訪問令牌的應用程式或服務。OAuth2客戶端代 ......

    uj5u.com 2023-05-09 07:48:16 more
  • 原來Spring能注入集合和Map的computeIfAbsent是這么好用!

    大家好,我是3y,今天繼續來聊我的開源專案austin啊,但實際內容更新不多。這文章主是想吹下水,主要聊聊我在更新專案中學到的小技巧。 今天所說的小技巧可能有很多人都會,但肯定也會有跟我一樣之前沒用過的。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息 ......

    uj5u.com 2023-05-09 07:48:05 more
  • 京東面經總結

    非科班,經歷了無數場秋招,現將面試京東的題目記錄如下: 一面 kafka在應用場景以及 專案 里的實作 bitmap底層 object里有哪些方法 hashmap相關 sychronized和reentrantlock相關問題以及鎖升級 cas和volatile 執行緒幾種狀態以及轉化 jvm記憶體模型 ......

    uj5u.com 2023-05-09 07:48:01 more
  • @RequestParam注解引數

    做業務的時候經常忘記@RequestParam注解引數,記錄一下 首先,我們要清楚@RequestParam是干什么的 @RequestParam:將請求引數系結到你控制器的方法引數上,路徑上有個引數+? @RequestParam注解引數: 語法:@RequestParam(value=https://www.cnblogs.com/zwy-yjy/archive/2023/05/08/”引數名” ......

    uj5u.com 2023-05-09 07:47:57 more
  • Django筆記三十八之發送郵件

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記三十八之發送郵件 這一篇筆記介紹如何在 Django 中發送郵件。 在 Python 中,提供了 smtplib 的郵件模塊,而 Django 在這個基礎上對其進行了封裝,我們可以通過 django.core.mail 來呼叫。 以下是本 ......

    uj5u.com 2023-05-09 07:47:50 more
  • 【深入淺出 Yarn 架構與實作】6-3 NodeManager 分布式快取

    不要跳過這部分知識,對了解 NodeManager 本地目錄結構,和熟悉 Container 啟動流程有幫助。 一、分布式快取介紹 主要作用就是將用戶應用程式執行時,所需的外部檔案資源下載快取到各個節點。 YARN 分布式快取作業流程如下: 客戶端將應用程式所需的檔案資源 (外部字典、JAR 包、二 ......

    uj5u.com 2023-05-09 07:47:41 more
  • Java后端真實、靠譜、強大的面試題網站:面試梯

    ? 本文分享一個給力的Java后端面試題網站:面試梯。 網址:https://offer.skyofit.com 這套題真實、高頻、全面、有詳細答案、保你穩過面試,讓你成為offer收割機。題目包括:Java基礎、多執行緒、JVM、資料庫、Redis、Shiro、Spring、SpringBoot、M ......

    uj5u.com 2023-05-09 07:47:35 more
  • spring事務傳播的Propagation.REQUIRES_NEW以及NEVER MANDATORY

    NEVER 不使用事務,如果當前事務存在,則拋出例外 驗證: @Service public class PrService { @Autowired PrDao dao; @Transactional public void savea() { dao.a();//保存第一條資料 saveb(); ......

    uj5u.com 2023-05-09 07:47:31 more
  • 第三章-Java的基本程式設計結構

    3.1一個簡單的Java語言程式 這是程式雖然很簡單,但是所有的Java程式都具有這種結構,因此還是值得花一些時間來研究的。首先,Java區分大小寫。如果出現了大小寫拼寫錯誤(例如:將main拼寫成Main),程式將無法運行。 下面逐行的查看這段源代碼。關鍵字pubilc稱為訪問修飾符(access ......

    uj5u.com 2023-05-09 07:47:23 more
  • python快速直白入門(半新手向,老手復習向)

    主用python做專案有一段時間,這次簡單總結學習下。為后面的專案撰寫,進行一次基礎知識的查缺補漏、 1、變數名和資料型別 """ 變數名,只能由" 數字、大小寫字母、_ " 組成,且不能以數字開頭 """ # 整數 int # hashable,不可變物件 a = 5 # 浮點數 float # ......

    uj5u.com 2023-05-09 07:41:56 more