Golang - Gin #17: 使用 Gin 實現 OAuth 驗證和授權

更新於 發佈於 閱讀時間約 3 分鐘
來源: Gin Logo + 自行用 Canva 製作

來源: Gin Logo + 自行用 Canva 製作

🛡️ 使用Gin實現OAuth驗證和授權

你好,開發者們!如今,OAuth 已經成為 Web 和移動應用中身份驗證和授權的黃金標準。這種協議允許用戶向第三方應用提供有限的訪問權限,而無需共享密碼。在這篇文章中,我們將探索如何在 Gin 框架中實現 OAuth 驗證和授權。

OAuth 提供了一個安全的方法,使得用戶可以授予應用訪問其資料的權限,而不需要直接提供他們的密碼。這意味著第三方應用無法訪問用戶的所有資料,只能訪問用戶允許的那部分資料。


🚀 實現OAuth驗證

  1. 設置OAuth提供者: 你需要首先在OAuth提供者(如Google、Facebook等)處設置你的應用,獲得client_idclient_secret
  2. 使用 Gin 和 go-oauth2 套件: 這個套件為 OAuth2.0 協議提供了完整的支援。
    import (
    "github.com/gin-gonic/gin"
    "golang.org/x/oauth2"
    "golang.org/x/oauth2/google"
    )

    var conf = &oauth2.Config{
    ClientID: "YOUR_CLIENT_ID",
    ClientSecret: "YOUR_CLIENT_SECRET",
    RedirectURL: "http://localhost:8080/auth/callback",
    Scopes: []string{"profile", "email"},
    Endpoint: google.Endpoint,
    }

    r.GET("/auth", func(c *gin.Context) {
    url := conf.AuthCodeURL("state", oauth2.AccessTypeOffline)
    c.Redirect(http.StatusFound, url)
    })

    r.GET("/auth/callback", func(c *gin.Context) {
    // 處理回調並獲得用戶資訊...
    })
  3. 處理OAuth回調: 當用戶授權之後,他們會被重定向回你的應用,帶有一個授權碼。你可以使用這個授權碼來獲得訪問令牌。
    r.GET("/auth/callback", func(c *gin.Context) {
    code := c.DefaultQuery("code", "")
    token, err := conf.Exchange(oauth2.NoContext, code)
    if err != nil {
    // 處理錯誤
    return
    }

    // 使用token獲取用戶資訊...
    })


🔐 授權

一旦你有了訪問令牌,你就可以使用它來訪問用戶的資料。要確保只訪問用戶授予你權限的資料。


🌟 結論

OAuth 提供了一個安全和高效的方式來實現身份驗證和授權。通過在你的Gin應用中實現 OAuth,你可以提供一個更安全、更易於使用的用戶體驗。希望這篇文章能幫助你輕鬆實現這一功能!




感謝

謝謝大家看完這篇,如果您喜歡我的文章,歡迎 小額贊助我 ^^
avatar-img
31會員
194內容數
歡迎來到【代碼的詩情】:探索程式語言之美 系列,這是一場優雅的程式之旅,透過詩歌的抒發,尋找不同程式語言的美感和精髓。 在這個系列中,我們將透過文字的韻律,深入探索多種程式語言的核心概念和語法,以及它們獨特的應用和技巧。每一篇詩歌都是一個故事,每一段代碼都是一句詩句,讓代碼的旋律和詩情在其中相互交織。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
KH Huang的沙龍 的其他內容
Hey,親愛的開發者!現代的 Web 應用面臨著各種惡意攻擊,這些攻擊可能損害你的服務、破壞用戶體驗或者帶來經濟損失。因此,建立一個強大的反作弊機制是每一位開發者的必修課。在這篇文章中,我們會深入探索在 Gin 應用中如何達到這一目的。
哈囉,親愛的開發者!當我們談論 Web 應用時,性能永遠都是最受關注的一個環節。無論是用戶體驗、搜索引擎排名,還是伺服器的成本,都與性能緊密相關。在這篇文章裡,我們會探討如何提高你的 Gin 應用的性能,並如何利用緩存來獲得更好的回應速度。
嗨,開發者們!在網頁應用的世界中,即時通訊是一個越來越重要的特點。WebSocket提供了一個高效的方式來支持這種通訊,並且能夠在客戶端和伺服器之間提供雙向的即時通訊。本篇文章將會帶你走進WebSocket的世界,並學習如何在Gin框架中實現它。
嗨,各位開發者!現代 Web 開發越來越傾向於前後端分離,使得前端框架和後端框架的協同工作變得非常重要。在這篇文章中,我們將專注於兩個極受歡迎的框架 —— Gin 和 Vue.js,探討如何將它們整合起來,為你的用戶提供流暢的Web 體驗。
當我們的 Web 應用越來越多地受到國際用戶的歡迎時,提供多語言支援就變得至關重要。在這篇文章中,我們將介紹如何在 Gin 中實現國際化和本地化,讓你的應用能夠輕鬆支援各種語言。
Hello!有沒有想過在你的 Gin Web 應用中實現一個圖片上傳功能?如果答案是肯定的,那麼你來對地方了!在這篇文章中,我們將探討如何輕鬆、快速地在Gin 中實現圖片上傳,並給你一些建議和最佳實踐,以確保你的文件上傳過程既安全又有效。
Hey,親愛的開發者!現代的 Web 應用面臨著各種惡意攻擊,這些攻擊可能損害你的服務、破壞用戶體驗或者帶來經濟損失。因此,建立一個強大的反作弊機制是每一位開發者的必修課。在這篇文章中,我們會深入探索在 Gin 應用中如何達到這一目的。
哈囉,親愛的開發者!當我們談論 Web 應用時,性能永遠都是最受關注的一個環節。無論是用戶體驗、搜索引擎排名,還是伺服器的成本,都與性能緊密相關。在這篇文章裡,我們會探討如何提高你的 Gin 應用的性能,並如何利用緩存來獲得更好的回應速度。
嗨,開發者們!在網頁應用的世界中,即時通訊是一個越來越重要的特點。WebSocket提供了一個高效的方式來支持這種通訊,並且能夠在客戶端和伺服器之間提供雙向的即時通訊。本篇文章將會帶你走進WebSocket的世界,並學習如何在Gin框架中實現它。
嗨,各位開發者!現代 Web 開發越來越傾向於前後端分離,使得前端框架和後端框架的協同工作變得非常重要。在這篇文章中,我們將專注於兩個極受歡迎的框架 —— Gin 和 Vue.js,探討如何將它們整合起來,為你的用戶提供流暢的Web 體驗。
當我們的 Web 應用越來越多地受到國際用戶的歡迎時,提供多語言支援就變得至關重要。在這篇文章中,我們將介紹如何在 Gin 中實現國際化和本地化,讓你的應用能夠輕鬆支援各種語言。
Hello!有沒有想過在你的 Gin Web 應用中實現一個圖片上傳功能?如果答案是肯定的,那麼你來對地方了!在這篇文章中,我們將探討如何輕鬆、快速地在Gin 中實現圖片上傳,並給你一些建議和最佳實踐,以確保你的文件上傳過程既安全又有效。
你可能也想看
Google News 追蹤
Thumbnail
/ 大家現在出門買東西還會帶錢包嗎 鴨鴨發現自己好像快一個禮拜沒帶錢包出門 還是可以天天買滿買好回家(? 因此為了記錄手機消費跟各種紅利優惠 鴨鴨都會特別注意銀行的App好不好用! 像是介面設計就是會很在意的地方 很多銀行通常會為了要滿足不同客群 會推出很多App讓使用者下載 每次
Thumbnail
什麼是多因素驗證 (MFA)? 多因素驗證 (MFA) 是一種登入保護機制,需要使用者提供多個不同的驗證方式來確認身份。除了輸入密碼,使用者還可能需要: 輸入發送到手機的驗證碼 掃描指紋或面部 回答安全問題 這樣即使密碼被盜用,未經授權的用戶也很難登入帳戶。 為什麼需要多因素
Thumbnail
需求情境: 為了讓多人使用 App,必須有驗證程序,以識別特定使用者,存取各自擁有的資源。 解決方案: 引用 google 所提供的雲端服務平台 Firebase,其中有多種驗證功能可選用。基於個人對 google 的偏愛,決定先採用 google signin 的方法,實作 login lo
在當今數位化快速發展的社會中,傳統的密碼驗證方法已逐漸顯露其局限性,如密碼遺忘、盜用以及安全漏洞等問題不斷。為解決這些問題,「FIDO(Fast Identity Online)認證」技術應運而生,旨在創造一個更安全、便利的網路認證環境。FIDO 認證不依賴傳統密碼,而是利用生物辨識技術如指紋、臉部
Thumbnail
這篇開箱另一套權限檢查工具 Vakt,相較於 Oso,Vakt 的規則直接以 Python 語法構成,不用再學 Oso 的特規語法,可以作為 Oso 的替代品。
Thumbnail
授權碼模式連線流程 用戶端請求自己的伺服器。 伺服器發現用戶沒登入,就導向認證伺服器。 認證伺服器顯示授權頁面,等待用戶授權。 用戶確認授權後,授權頁面會向認證伺服器請求授權碼。 用戶獲取授權碼。 用戶將授權碼傳給伺服器。 伺服器拿授權碼向認證伺服器取得token。 應用註冊
Thumbnail
金融業需遵守金檢規則,建立API分級協助和管理程序確保API合規,使用OAuth 2.0和API KEY授權功能降低風險,實行API認證和金鑰機制保障資料安全。監控API使用,建立控制機制,選擇優良的APIM,提供全面的API管理和安全。
Thumbnail
/ 大家現在出門買東西還會帶錢包嗎 鴨鴨發現自己好像快一個禮拜沒帶錢包出門 還是可以天天買滿買好回家(? 因此為了記錄手機消費跟各種紅利優惠 鴨鴨都會特別注意銀行的App好不好用! 像是介面設計就是會很在意的地方 很多銀行通常會為了要滿足不同客群 會推出很多App讓使用者下載 每次
Thumbnail
什麼是多因素驗證 (MFA)? 多因素驗證 (MFA) 是一種登入保護機制,需要使用者提供多個不同的驗證方式來確認身份。除了輸入密碼,使用者還可能需要: 輸入發送到手機的驗證碼 掃描指紋或面部 回答安全問題 這樣即使密碼被盜用,未經授權的用戶也很難登入帳戶。 為什麼需要多因素
Thumbnail
需求情境: 為了讓多人使用 App,必須有驗證程序,以識別特定使用者,存取各自擁有的資源。 解決方案: 引用 google 所提供的雲端服務平台 Firebase,其中有多種驗證功能可選用。基於個人對 google 的偏愛,決定先採用 google signin 的方法,實作 login lo
在當今數位化快速發展的社會中,傳統的密碼驗證方法已逐漸顯露其局限性,如密碼遺忘、盜用以及安全漏洞等問題不斷。為解決這些問題,「FIDO(Fast Identity Online)認證」技術應運而生,旨在創造一個更安全、便利的網路認證環境。FIDO 認證不依賴傳統密碼,而是利用生物辨識技術如指紋、臉部
Thumbnail
這篇開箱另一套權限檢查工具 Vakt,相較於 Oso,Vakt 的規則直接以 Python 語法構成,不用再學 Oso 的特規語法,可以作為 Oso 的替代品。
Thumbnail
授權碼模式連線流程 用戶端請求自己的伺服器。 伺服器發現用戶沒登入,就導向認證伺服器。 認證伺服器顯示授權頁面,等待用戶授權。 用戶確認授權後,授權頁面會向認證伺服器請求授權碼。 用戶獲取授權碼。 用戶將授權碼傳給伺服器。 伺服器拿授權碼向認證伺服器取得token。 應用註冊
Thumbnail
金融業需遵守金檢規則,建立API分級協助和管理程序確保API合規,使用OAuth 2.0和API KEY授權功能降低風險,實行API認證和金鑰機制保障資料安全。監控API使用,建立控制機制,選擇優良的APIM,提供全面的API管理和安全。