1
0
mirror of https://github.com/labstack/echo.git synced 2025-01-24 03:16:14 +02:00
echo/website/content/recipes/jwt-authentication.md
Vishal Rana fbf37ec2f4 Changed standard#WrapMiddleware
Signed-off-by: Vishal Rana <vr@labstack.com>
2016-03-09 23:24:45 -08:00

2.1 KiB

title menu
JWT Authentication
side
parent weight
recipes 11

Most applications dealing with client authentication will require a more secure mechanism than that provided by basic authentication. JSON Web Tokens are one such mechanism - JWTs are a compact means of transferring cryptographically signed claims between the client and server.

This recipe demonstrates the use of a simple JWT authentication Echo middleware using Dave Grijalva's jwt-go. This middleware expects the token to be present in an Authorization HTTP header using the method "Bearer", although JWTs are also frequently sent using cookies, the request URL, or even the request body. We will use the HS236 signing method, note that several other algorithms are available.

main.go

{{< embed "jwt-authentication/main.go" >}}

Run main.go and making a request to the root path / returns a 200 OK response, as this route does not use our JWT authentication middleware. Sending requests to /restricted (our authenticated route) with either no Authorization header or invalid Authorization headers / tokens will return 401 Unauthorized.

# Unauthenticated route
$ curl localhost:1323/  => No auth required for this route.

# No Authentication header
$ curl localhost:1323/restricted  => Unauthorized

# Invalid Authentication method
$  curl localhost:1323/restricted -H "Authorization: Invalid " => Unauthorized

# Invalid token
$  curl localhost:1323/restricted -H "Authorization: Bearer InvalidToken" => Unauthorized

Running token.go (source) will print JWT that is valid against this middleware to stdout. You can use this token to test succesful authentication on the /restricted path.

{{< embed "jwt-authentication/token/token.go" >}}

# Valid token
$  curl localhost:1323/restricted -H "Authorization: Bearer <token>" => Access granted with JWT.

Maintainers

[Source Code]({{< source "jwt-authentication" >}})