インターネットの急速な発展に伴い、ユーザー認証と認可を実装する必要があるアプリケーションがますます増えており、OAuth2.0 は最も人気のある認可フレームワークの 1 つとして、Web アプリケーションやモバイル アプリケーションで広く使用されています。 JWT (JSON Web Token) は、開発者がクライアントとサーバー間で情報を安全に送信できるようにする、広く使用されている認証標準です。 Golang プロジェクトに JWT を使用して OAuth2.0 認証を実装するのは非常に簡単ですので、以下にその実装方法を紹介します。
JWT を使用する前に、Golang に jwt-go ライブラリをインストールする必要があります。次のコマンドを使用してインストールを完了します。
go get github.com/dgrijalva/jwt-go
JWT を使用して OAuth2.0 認証を実装する方法を紹介する前に、まず JWT の基本概念と動作原理を理解しましょう。標準の認証方式として、JWT には次の特徴があります。
JWT 認証プロセスは次のとおりです。
import ( "github.com/dgrijalva/jwt-go" ) func CreateJWT() (string, error) { // 设置密钥 secret := []byte("secret") // 设置载荷信息 token := jwt.New(jwt.SigningMethodHS256) claims := token.Claims.(jwt.MapClaims) claims["authorized"] = true claims["user_id"] = 1 claims["exp"] = time.Now().Add(time.Minute * 30).Unix() // 创建JWT令牌 tokenString, err := token.SignedString(secret) if err != nil { return "", err } return tokenString, nil }上記のコードでは、キーを「secret」に設定し、ペイロード情報にはユーザー認証ステータス、ユーザー ID、有効期限が含まれています。時間。最後に、token.SignedString メソッドを使用して JWT トークンを作成します。 3.2 JWT トークンの検証クライアントがリクエストを送信するとき、JWT トークンはローカルに保存される必要があり、JWT トークンは各リクエストの Authorization ヘッダーとして送信される必要があります。リクエストを受信した後、サーバーは JWT トークンの有効性を検証する必要があります。 次のコードを使用して JWT トークンを確認します。
import ( "github.com/dgrijalva/jwt-go" ) func VerifyJWT(tokenString string) (jwt.MapClaims, error) { // 设置密钥 secret := []byte("secret") // 解析JWT令牌 token, err := jwt.Parse(tokenString, func(token *jwt.Token) (interface{}, error) { if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok { return nil, fmt.Errorf("unexpected signing method: %v", token.Header["alg"]) } return secret, nil }) if err != nil { return nil, err } // 校验JWT令牌 if claims, ok := token.Claims.(jwt.MapClaims); ok && token.Valid { return claims, nil } return nil, fmt.Errorf("invalid token") }上記のコードでは、キーを「secret」に設定し、jwt.Parse メソッドを使用して JWT トークンを解析します。 use token .Claims.(jwt.MapClaims) はペイロード情報を MapClaims 型に変換します。最後に、JWT トークンが有効であることを確認します。
以上がJWT を使用して Golang プロジェクトに OAuth2.0 認証を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。