使用Golang輕松實(shí)現(xiàn)JWT身份驗(yàn)證的示例代碼
JSON Web Tokens (JWT)是一種流行的安全方法,用于在兩個(gè)方之間表示聲明。在Web應(yīng)用程序領(lǐng)域,它們通常用作從客戶端向服務(wù)器傳輸身份信息(聲明)的方式。本教程將引導(dǎo)您逐步實(shí)現(xiàn)Go應(yīng)用程序中的JWT身份驗(yàn)證過程。
什么是JWT
JSON Web Token (JWT)是一種緊湊且URL安全的方式,用于在兩個(gè)方之間傳輸聲明。JWT中的聲明被編碼為一個(gè)JSON對(duì)象,并使用JSON Web Signature (JWS)進(jìn)行數(shù)字簽名。
JWT通常的格式為:xxxxx.yyyyy.zzzzz
- 頭部:頭部(xxxxx)通常由兩部分組成:令牌類型JWT和簽名算法。
- 負(fù)載:負(fù)載(yyyyy)包含了聲明。聲明是關(guān)于主題(用戶)的陳述。
- 簽名:要?jiǎng)?chuàng)建簽名(zzzzz)部分,您需要使用編碼后的頭部、編碼后的負(fù)載、一個(gè)密鑰以及頭部中指定的算法進(jìn)行簽名。
Go環(huán)境設(shè)置
首先,您需要一個(gè)用于在Go中處理JWT的軟件包。我們將使用github.com/golang-jwt/jwt軟件包。[1]
在Go中生成JWT
讓我們創(chuàng)建一個(gè)生成JWT的函數(shù):
package main import ( "fmt" "github.com/golang-jwt/jwt/v4" "time" ) var mySigningKey = []byte("secretpassword") func GenerateJWT() (string, error) { token := jwt.New(jwt.SigningMethodHS256) claims := token.Claims.(jwt.MapClaims) claims["authorized"] = true claims["user"] = "John Doe" claims["exp"] = time.Now().Add(time.Minute * 30).Unix() tokenString, err := token.SignedString(mySigningKey) if err != nil { fmt.Errorf("Something went wrong: %s", err.Error()) return "", err } return tokenString, nil }
在Go中驗(yàn)證JWT
現(xiàn)在,讓我們驗(yàn)證JWT:
func ValidateToken(tokenString string) (*jwt.Token, error) { token, err := jwt.Parse(tokenString, func(token *jwt.Token) (interface{}, error) { if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok { return nil, fmt.Errorf("There was an error") } return mySigningKey, nil }) if err != nil { return nil, err } return token, nil }
在Go Web應(yīng)用程序中使用JWT進(jìn)行身份驗(yàn)證
以下是一個(gè)簡單示例,在Go的HTTP服務(wù)器中集成了JWT生成和驗(yàn)證:
package main import ( "fmt" "log" "net/http" ) func HomePage(w http.ResponseWriter, r *http.Request) { validToken, err := GenerateJWT() if err != nil { fmt.Fprintf(w, err.Error()) } clientToken := r.Header.Get("Token") if clientToken != validToken { w.WriteHeader(http.StatusUnauthorized) fmt.Fprintf(w, "Token is not valid") return } fmt.Fprintf(w, "Hello, World!") } func handleRequests() { http.HandleFunc("/", HomePage) log.Fatal(http.ListenAndServe(":9000", nil)) } func main() { handleRequests() }
使用此設(shè)置:
- 服務(wù)器在訪問主頁時(shí)創(chuàng)建一個(gè)JWT。
- 要進(jìn)行驗(yàn)證,客戶端需要在標(biāo)頭“Token”中發(fā)送相同的JWT。
- 這只是一個(gè)基本示例。在實(shí)際情況中,您會(huì)在登錄后生成一個(gè)令牌,并在每個(gè)需要身份驗(yàn)證的請(qǐng)求上進(jìn)行檢查。
JWT提供了一種強(qiáng)大而靈活的方法來處理Web應(yīng)用程序中的身份驗(yàn)證和授權(quán)。在Go中,借助像github.com/golang-jwt/jwt[2]這樣的軟件包,實(shí)現(xiàn)基于JWT的身份驗(yàn)證非常簡單。但請(qǐng)記住,始終保持您的簽名密鑰保密,并在生產(chǎn)應(yīng)用程序中使用安全的方法,最好是RSA,以增加安全性。
到此這篇關(guān)于使用Golang輕松實(shí)現(xiàn)JWT身份驗(yàn)證的示例代碼的文章就介紹到這了,更多相關(guān)Go實(shí)現(xiàn)JWT身份驗(yàn)證內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何使用Golang創(chuàng)建與讀取Excel文件
我最近工作忙于作圖,圖表,需要自己準(zhǔn)備數(shù)據(jù)源,所以經(jīng)常和Excel打交道,下面這篇文章主要給大家介紹了關(guān)于如何使用Golang創(chuàng)建與讀取Excel文件的相關(guān)資料,需要的朋友可以參考下2022-07-07向Rust學(xué)習(xí)Go考慮簡單字符串插值特性示例解析
這篇文章主要為大家介紹了向Rust學(xué)習(xí)Go考慮簡單字符串插值特性示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02Go語言的結(jié)構(gòu)體還能這么用?看這篇就夠了
這篇文章主要為大家詳細(xì)介紹了Go語言結(jié)構(gòu)體的各個(gè)知識(shí)點(diǎn),最后還介紹了空結(jié)構(gòu)體的3種妙用。文中的示例代碼講解詳細(xì),希望對(duì)大家有所幫助2023-02-02Go type關(guān)鍵字(類型定義與類型別名的使用差異)用法實(shí)例探究
這篇文章主要為大家介紹了Go type關(guān)鍵字(類型定義與類型別名的使用差異)用法實(shí)例探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01