在現代Web開發中,安全且可擴展的認證至關重要。 JSON Web Tokens (JWT) 已成為實現這一目標的標準方法。在本篇部落格文章中,我們將探討JWT是什麼,它是如何運作的,以及如何在Golang中實現它。
JSON Web Token (JWT) 是一種緊湊的、URL安全的表示聲明的方式,用於在雙方之間安全地傳輸聲明。它通常用於在API和分散式系統中對使用者進行身份驗證和授權。
JWT由三個以點 (.) 分隔的部分組成:
<code>Header.Payload.Signature</code>
範例:
<code>eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWUsImlhdCI6MTUxNjIzOTAyMn0.reGQzG3OKdoIMWLDKOZ4TICJit3EW69cQE72E2CfzRE</code>
每個部分是:
<code>{ "alg": "HS256", "typ": "JWT" }</code>
<code>{ "sub": "1234567890", "name": "John Doe", "admin": true, "iat": 1516239022 }</code>
簽署的建立方式:
- 連接編碼的Header和Payload:
<code> base64UrlEncode(header) + "." + base64UrlEncode(payload)</code>
- 簽名結果:
- 使用秘密金鑰或私鑰使用加密簽章演算法(例如,HMACSHA256、RS256)。
- 附加簽名: 最終的JWT變成
<code> header.payload.signature</code>
Golang開發人員可以利用優秀的golang-jwt/jwt函式庫來處理JWT。此庫提供了創建、簽署和驗證JWT的強大功能。您可以在此處找到它。
但是,管理JWT通常需要重複的任務,例如配置簽署方法、解析令牌和驗證聲明。為了簡化這一點,我編寫了一個自訂套件來包裝golang-jwt的功能。您可以在此處查看我的包。
以下是如何使用我的自訂JWT套件的範例。
<code class="language-go">package main import ( "context" "fmt" "log" "time" "github.com/golang-jwt/jwt/v5" jwtutil "github.com/kittipat1413/go-common/util/jwt" ) type MyCustomClaims struct { jwt.RegisteredClaims UserID string `json:"uid"` } func main() { ctx := context.Background() signingKey := []byte("super-secret-key") manager, err := jwtutil.NewJWTManager(jwtutil.HS256, signingKey) if err != nil { log.Fatalf("Failed to create JWTManager: %v", err) } // Prepare custom claims claims := &MyCustomClaims{ RegisteredClaims: jwt.RegisteredClaims{ ExpiresAt: jwt.NewNumericDate(time.Now().Add(15 * time.Minute)), Issuer: "example-HS256", Subject: "example-subject", }, UserID: "abc123", } // Create the token tokenStringHS256, err := manager.CreateToken(ctx, claims) if err != nil { log.Fatalf("Failed to create token: %v", err) } fmt.Println("Generated Token:", tokenStringHS256) // Validate the token parsedClaims := &MyCustomClaims{} err = manager.ParseAndValidateToken(ctx, tokenStringHS256, parsedClaims) if err != nil { log.Fatalf("Failed to validate token: %v", err) } fmt.Printf("Token is valid! UserID: %s, Issuer: %s\n", parsedClaims.UserID, parsedClaims.Issuer) }</code>
您可以在GitHub上瀏覽我的套件的完整實作和文件:此處。
JWT是用於安全、無狀態身份驗證的強大工具。簽名確保了令牌的完整性和真實性,使JWT成為API和分散式系統的理想選擇。使用像jwt-go這樣的函式庫,您可以輕鬆地在Golang專案中實作JWT。
如果您喜歡我的工作,請考慮請我喝杯咖啡!您的支持幫助我繼續創作有價值的內容並分享知識。 ☕
以上是Golang 中的 JWT 令牌:安全 API 開發人員指南的詳細內容。更多資訊請關注PHP中文網其他相關文章!