ホームページ > バックエンド開発 > Golang > golang jwt フロントエンドを確認する方法

golang jwt フロントエンドを確認する方法

リリース: 2019-12-24 10:59:28
オリジナル
2351 人が閲覧しました

golang jwt フロントエンドを確認する方法

golang jwt フロントエンド検証方法:

クライアントはリクエスト オブジェクト ヘッダーにトークン パラメーターを追加してサーバーに送信し、サーバーそれを取り出してトークンを比較します。

トークンの最初の生成は、アカウントが存在し、正しいことを確認するためにログイン後に発生します。ユーザーにはトークン (暗号化された文字列) が与えられ、そのトークンは応答のヘッダーに配置されます。顧客 クライアントがログインに成功すると、レスポンスからトークンが取り出され、後続の操作リクエストのヘッダーにトークンが追加され、トークンの有効期限が切れると、再度ログインすることでのみ新しいトークンを取得できます。

実装:

server_token が生成され、応答のヘッダーに挿入されます。
フロントエンドは、response.headers['x-auth-token']# を受け入れて取得します。 ##

import "github.com/fwhezfwhez/jwt"
func Login(c *gin.Context){
	...(验证身份正确)
	//获取token管理对象
	token := jwt.GetToken()
	//添加令牌关键信息
	token.AddPayLoad("userName", user.UserName).AddPayLoad("role", "admin").AddHeader("typ", "JWT").AddHeader("alg", "HS256")
	//添加令牌期限
	exp:=time.Now().Add(1*time.Hour)
	token.AddPayLoad("exp", strconv.FormatInt(exp.Unix(), 10))
	//获取令牌,并添加进reponse的header里
	jwts, _, erre := token.JwtGenerator(consts.Secret)
	if erre != nil {
		fmt.Println("token生成出错")
		return
	}
	fmt.Println("生成的jwt是:", jwts)
	c.Writer.Header().Add("x-auth-token", jwts)
	...
	}
ログイン後にコピー

Client_ログイン リクエストを送信

var Token string
func main(){
		...
		var content = fmt.Sprintf("userName=admin&password=123456")
		t1 := time.Now()
		resp, err := http.Post(host+"v1/POST/user/login", "application/x-www-form-urlencoded", strings.NewReader(content))
		Token =resp.Header.Get("x-auth-token")
		t2 := time.Now()
		fmt.Println(t2.Sub(t1))
		if err != nil {
			panic(err)
		}
		helpRead(resp)
		...
		}
ログイン後にコピー

Client_リストを取得するために他の関数にリクエスト

		...
		t1 := time.Now()

		//resp, err := http.Get(host + "v1/GET/mediums/list")
		client := &http.Client{}
		req, err := http.NewRequest("GET", "http://localhost:8087/v1/GET/mediums/list",nil)
		req.Header.Add("x-auth-token", Token)
		resp, err := client.Do(req)
		t2 := time.Now()
		fmt.Println(t2.Sub(t1))
		if err != nil {
			panic(err)
		}
		helpRead(resp)
		...
ログイン後にコピー

Server_Token検証

func main(){
	...
	router := gin.Default()
	//Login不需要令牌验证,所以写中间件前面
	router.POST(consts.LoginURL, userControl.Login)

	router.Use(Validate())
	//后续的监听都需要通过Validate()的验证
	router.GET(consts.GetMediumsURL, mediumControl.GetMediums)
	router.....
	...
	}
func Validate()gin.HandleFunc{
return func(c *gin.Context) {
		if JWTToken := c.Request.Header.Get("x-auth-token");JWTToken!=""{
			token :=jwt.GetToken()
			legal,err:=token.IsLegal(JWTToken,consts.Secret)
			if err!=nil{
				fmt.Println(err)
				c.Abort()
				c.JSON(200,consts.ResponseTokenValidateError)
				return
			}
			if !legal{
				c.Abort()
				c.JSON(200,consts.ResponseTokenValidateWrong)
				return
			}
			c.Next()
		}else{
			c.JSON(200, consts.ResponseTokenNotFound)
			c.Abort()
			return
		}
	}
}
ログイン後にコピー

Golangの知識の詳細については、PHP中国語に注意してください。ウェブサイトの

golang チュートリアル 列。

以上がgolang jwt フロントエンドを確認する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート