Go Language and Verify JWT

前端 未结 1 2019
北荒
北荒 2020-12-09 17:32

I have been searching for an example I can understand of how to validate the signature of a JWT with the GO Language.

This might be especially tricky since I am usin

相关标签:
1条回答
  • 2020-12-09 17:55

    Below is an example of JWT decoding and verification. It uses both the jwt-go and jwk packages:

    package main
    
    import (
        "errors"
        "fmt"
    
        "github.com/dgrijalva/jwt-go"
        "github.com/lestrrat-go/jwx/jwk"
    )
    
    const token = `eyJhbGciOiJSUzI1NiIsImtpZCI6Ind5TXdLNEE2Q0w5UXcxMXVvZlZleVExMTlYeVgteHlreW1ra1h5Z1o1T00ifQ.eyJzdWIiOiIwMHUxOGVlaHUzNDlhUzJ5WDFkOCIsIm5hbWUiOiJva3RhcHJveHkgb2t0YXByb3h5IiwidmVyIjoxLCJpc3MiOiJodHRwczovL2NvbXBhbnl4Lm9rdGEuY29tIiwiYXVkIjoidlpWNkNwOHJuNWx4ck45YVo2ODgiLCJpYXQiOjE0ODEzODg0NTMsImV4cCI6MTQ4MTM5MjA1MywianRpIjoiSUQuWm9QdVdIR3IxNkR6a3RUbEdXMFI4b1lRaUhnVWg0aUotTHo3Z3BGcGItUSIsImFtciI6WyJwd2QiXSwiaWRwIjoiMDBveTc0YzBnd0hOWE1SSkJGUkkiLCJub25jZSI6Im4tMFM2X1d6QTJNaiIsInByZWZlcnJlZF91c2VybmFtZSI6Im9rdGFwcm94eUBva3RhLmNvbSIsImF1dGhfdGltZSI6MTQ4MTM4ODQ0MywiYXRfaGFzaCI6Im1YWlQtZjJJczhOQklIcV9CeE1ISFEifQ.OtVyCK0sE6Cuclg9VMD2AwLhqEyq2nv3a1bfxlzeS-bdu9KtYxcPSxJ6vxMcSSbMIIq9eEz9JFMU80zqgDPHBCjlOsC5SIPz7mm1Z3gCwq4zsFJ-2NIzYxA3p161ZRsPv_3bUyg9B_DPFyBoihgwWm6yrvrb4rmHXrDkjxpxCLPp3OeIpc_kb2t8r5HEQ5UBZPrsiScvuoVW13YwWpze59qBl_84n9xdmQ5pS7DklzkAVgqJT_NWBlb5uo6eW26HtJwHzss7xOIdQtcOtC1Gj3O82a55VJSQnsEEBeqG1ESb5Haq_hJgxYQnBssKydPCIxdZiye-0Ll9L8wWwpzwig`
    
    const jwksURL = `https://companyx.okta.com/oauth2/v1/keys`
    
    func getKey(token *jwt.Token) (interface{}, error) {
    
        // TODO: cache response so we don't have to make a request every time
        // we want to verify a JWT
        set, err := jwk.FetchHTTP(jwksURL)
        if err != nil {
            return nil, err
        }
    
        keyID, ok := token.Header["kid"].(string)
        if !ok {
            return nil, errors.New("expecting JWT header to have string kid")
        }
    
        if key := set.LookupKeyID(keyID); len(key) == 1 {
            return key[0].Materialize()
        }
    
        return nil, fmt.Errorf("unable to find key %q", keyID)
    }
    
    func main() {
        token, err := jwt.Parse(token, getKey)
        if err != nil {
            panic(err)
        }
        claims := token.Claims.(jwt.MapClaims)
        for key, value := range claims {
            fmt.Printf("%s\t%v\n", key, value)
        }
    }
    
    0 讨论(0)
提交回复
热议问题