1
0
mirror of https://github.com/labstack/echo.git synced 2025-01-10 00:28:23 +02:00
echo/website/content/recipes/jwt.md
Vishal Rana f4b0004d2b website/recipe in the main repo
Signed-off-by: Vishal Rana <vr@labstack.com>
2016-10-20 09:11:07 -07:00

1.3 KiB

+++ title = "JWT Recipe" description = "JWT recipe / example for Echo" [menu.side] name = "JWT" identifier = "jwt-recipe" parent = "recipes" weight = 11 +++

JWT Recipe

  • JWT authentication using HS256 algorithm.
  • JWT is retrieved from Authorization request header.

Server using Map claims

server.go

{{< embed "jwt/map-claims/server.go" >}}

Server using custom claims

server.go

{{< embed "jwt/custom-claims/server.go" >}}

Client

curl

Login

Login using username and password to retrieve a token.

curl -X POST -d 'username=jon' -d 'password=shhh!' localhost:1323/login

Response

{
  "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE0NjE5NTcxMzZ9.RB3arc4-OyzASAaUhC2W3ReWaXAt_z2Fd3BN4aWTgEY"
}

Request

Request a restricted resource using the token in Authorization request header.

curl localhost:1323/restricted -H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE0NjE5NTcxMzZ9.RB3arc4-OyzASAaUhC2W3ReWaXAt_z2Fd3BN4aWTgEY"

Response

Welcome Jon Snow!

Maintainers

Source Code

  • [With default Map claims]({{< source "jwt/map-claims" >}})
  • [With custom claims]({{< source "jwt/custom-claims" >}})