This is a demonstration of stateless token-based authentication using JSON Web Token and CSRF protection, Spring Security, Spring Boot and Vue js.
Component | Technology |
---|---|
Frontend | Vue.js 2 |
Backend (REST) | SpringBoot (Java) |
Security | Token Based (Spring Security, JJWT, CSRF) |
Client Build Tools | vue-cli, Webpack, npm |
Server Build Tools | Maven |
Run Environment: Java11, Node 12, Maven3
Clone this project
git clone https://github.com/PuZhiweizuishuai/SpringSecurity-JWT-Vue-Deom.git
Run back end server
cd spring-security-jwt
mvn clean package
Then
java -jar target/security-0.0.1-SNAPSHOT.jar
Run front end server
cd vue
npm install
Then
npm run serve
Final
Open
http://127.0.0.1:8080
To generating and verifying JWT I use JJWT. JJWT – a self-contained Java library providing end-to-end JSON Web Tokens creation and verification.
We have a couple of options where to store the token:
HTML5 Web Storage (localStorage or sessionStorage) Cookies
It is accessible through JavaScript on the same domain. This means that any JavaScript running on your site will have access to web storage, and because of this can be vulnerable to cross-site scripting (XSS) attacks.
So, to prevent XSS I store the JWT token in a Http-Only/Secure cookie. Cookies, when used with the HttpOnly cookie flag, are not accessible through JavaScript, and are immune to XSS.
However, cookies are vulnerable to a different type of attack: cross-site request forgery (CSRF). A CSRF attack is a type of attack that occurs when a malicious web site, email, or blog causes a user’s web browser to perform an unwanted action on a trusted site on which the user is currently authenticated.
To prevent CSRF attacks, we must create an extra Javascript readable cookie which is called: XSRF-TOKEN. This cookie must be created when the user is logged in and should contain a random, un-guessable string. Every time the JavaScript application wants to make a request, it will need to read this token and send it along in a custom HTTP header.
The code is released under the MIT license.