/jwt-spring-security-demo

A small demo for using JWT (Json Web Token) with Spring Security and Spring Boot

Primary LanguageJavaMIT LicenseMIT

JWT Spring Security Demo

Screenshot from running application

##About This is just a simple demo for using JWT (JSON Web Token) with Spring Security and Spring Boot. This solution is partially based on the blog entry REST Security with JWT using Java and Spring Security and the demo project Cerberus. Thanks to the authors!

##Requirements This demo is build with with Maven and Java 1.8.

##Usage Just start the application with the Spring Boot maven plugin (mvn spring-boot:run). The application is running at http://localhost:8080.

There are three user accounts present to demonstrate the different levels of access to the endpoints in the API and the different authorization exceptions:

Admin - admin:admin
User - user:password
Disabled - disabled:password (this user is disabled)

There are three endpoints that are reasonable for the demo:

/auth - authentication endpoint with unrestricted access
/persons - an example endpoint that is restricted to authorized users (a valid JWT token must be present in the request header)
/protected - an example endpoint that is restricted to authorized users with the role 'ROLE_ADMIN' (a valid JWT token must be present in the request header)

I've written a small Javascript client and put some comments in the code that hopefully makes this demo understandable.

##Creator

Stephan Zerhusen

##Copyright and license

The code is released under the MIT license.


Please feel free to send me some feedback or questions!