forked from mirror/jwt
30 lines
948 B
Markdown
30 lines
948 B
Markdown
A [golang](http://www.golang.org) implementation of [JSON Web Tokens](http://self-issued.info/docs/draft-jones-json-web-token.html)
|
|
|
|
This library supports the parsing and verification as well as the generation and signing of JWTs. Current supported signing algorithms are RSA256 and HMAC SHA256.
|
|
|
|
This library is considered production ready. Feedback and feature requests are appreciated.
|
|
|
|
## Parse and Verify
|
|
```go
|
|
token, err := jwt.Parse(myToken, func(token *jwt.Token) ([]byte, error) {
|
|
return myLookupKey(token.Header["kid"])
|
|
})
|
|
|
|
if err == nil && token.Valid {
|
|
deliverGoodness("!")
|
|
} else {
|
|
deliverUtterRejection(":(")
|
|
}
|
|
```
|
|
|
|
## Create a token
|
|
|
|
```go
|
|
token := jwt.New(jwt.GetSigningMethod("HS256"))
|
|
token.Claims["foo"] = "bar"
|
|
token.Claims["exp"] = time.Now().Add(time.Hour * 72).Unix()
|
|
tokenString, err := token.SignedString(mySigningKey)
|
|
```
|
|
|
|
Documentation can be found [here](http://godoc.org/github.com/dgrijalva/jwt-go)
|