亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何檢查 JWT 的角色聲明(值數組)的某個值?

如何檢查 JWT 的角色聲明(值數組)的某個值?

Go
浮云間 2023-07-04 15:06:59
我正在使用 Golang 和 Gin 框架從客戶端發送的 JWT 獲取聲明。但我無法將提取的角色與字符串進行比較。當我嘗試獲取該值時,它會返回,[test-app] 但實際上我希望該值為"test-app"token, _, err := new(jwt.Parser).ParseUnverified(tokenString, jwt.MapClaims{})if err != nil {    fmt.Println(err2)    return}if claims, ok := token.Claims.(jwt.MapClaims); ok {   chkRoles := claims["roles"]   if chkRoles == "test-app" {        fmt.Println("Check Roles passed")   }} 和我的有效負載    {        "roles": [            "test-app"        ],        "exp": 1811749673,        "client_id": "testapp"    }如何從 json 聲明中獲取值并使用它與字符串進行比較/驗證?
查看完整描述

1 回答

?
MMTTMM

TA貢獻1869條經驗 獲得超4個贊

rolesJWT 有效負載中的聲明是一個數組,因此它也可以包含多個值,例如"roles":["test-app", "production-app"]


chkRoles因此 aslice包含這些值。您可以通過索引訪問它們,例如chkRoles[0],但是如果您不知道在哪個位置可以找到您要查找的值,您可以像這樣迭代切片:


chkRoles := claims["roles"].([]interface{})

for _, role:=range chkRoles {

  if role == "test-app" {

    fmt.Println("Check Roles passed")

    break

  }

}

通過此代碼,您將了解roles聲明是否包含值“test-app”。


這是一個完整的程序:


package main


import (

    "fmt"

    "github.com/dgrijalva/jwt-go"   

)


func main() {

    tokenString := "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYW1lIjoiSm9obiBEb2UiLCJyb2xlcyI6WyJ0ZXN0LWFwcCIsInByb2R1Y3Rpb24tYXBwIl0sImlhdCI6MTUxNjIzOTAyMn0.4VHXYkAXgFkgbQ524ijVClPVJb0GuXRtAVNp3yuGwvA"


    token, _, err := new(jwt.Parser).ParseUnverified(tokenString, jwt.MapClaims{})

    if err != nil {

        fmt.Println(err)

        return

    }


    if claims, ok := token.Claims.(jwt.MapClaims); ok {


        chkRoles := claims["roles"].([]interface{})


        for _, role := range chkRoles {

            if role == "test-app" {

                fmt.Println("Check Roles passed")

                break

            }

        }

    }

}

可以在 Go Playground 上查看和測試完整的工作示例



查看完整回答
反對 回復 2023-07-04
  • 1 回答
  • 0 關注
  • 135 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號