DEV Community

Cover image for Angular 11 + Spring Boot: JWT Authentication example (with Authorization)
bezkoder
bezkoder

Posted on • Edited on

Angular 11 + Spring Boot: JWT Authentication example (with Authorization)

In this tutorial, I will show you how to build a full stack Angular 11 + Spring Boot JWT Authentication example. The back-end server uses Spring Boot with Spring Security for JWT Authentication & Authorization, Spring Data JPA for interacting with database. The front-end will be built using Angular 11 with HttpInterceptor & Form validation.

Full Article: https://bezkoder.com/angular-11-spring-boot-jwt-auth/

Github Source code:
https://github.com/bezkoder/angular-11-spring-boot-jwt-authentication

Newer version with HttpOnly Cookie:
Angular 13 + Spring Boot: JWT Authentication & Authorization example

Angular 11 Spring Boot Authentication example

It will be a full stack, with Spring Boot for back-end and Angular 11 for front-end. The system is secured by Spring Security with JWT Authentication.

User can signup new account, login with username & password.
Authorization by the role of the User (admin, moderator, user).

Screenshots

Here are UI screenshots of our system.

– Anyone can access a public page before logging in:

Alt Text

– New user registration:

Alt Text

– Signup Form Validation:

Alt Text

– After signup is successful, User can login:

Alt Text

-Loggedin User can access Profile page/ User page:

Alt Text

Alt Text

– This is UI for admin:

Alt Text

– If a User who doesn’t have Admin role tries to access Admin/Moderator Board page:

Alt Text

Demo

This is full Angular + Spring Boot JWT authentication demo (with form validation, check signup username/email duplicates, test authorization with 3 roles: Admin, Moderator, User).

Flow for User Registration and User Login

The diagram shows flow for User Registration process and User Login process.
Alt Text

It’s not too difficult to understand. We have 2 endpoints for authentication:

  • api/auth/signup for User Registration
  • api/auth/signin for User Login

If Client wants to send request to protected data/endpoints, a legal JWT must be added to HTTP Authorization Header.

Spring Boot & Spring Security for Back-end

Alt Text

Angular 11 for Front-end

Alt Text

For more details, please visit:
https://bezkoder.com/angular-11-spring-boot-jwt-auth/

Newer version with HttpOnly Cookie:
Angular 13 + Spring Boot: JWT Authentication & Authorization example

Top comments (1)

Collapse
 
mamadoucherifb3 profile image
Mamadou cherif barry

thank you for this wonderfull tutorial, but it doen't really work for me.
Let me show you the loged error. thank you in advance for your response!

2021-02-19 19:06:07.502 WARN 10048 --- [nio-8080-exec-3] o.s.s.c.bcrypt.BCryptPasswordEncoder : Encoded password does not look like BCrypt
2021-02-19 19:06:07.503 ERROR 10048 --- [nio-8080-exec-3] c.b.s.security.jwt.AuthEntryPointJwt : Unauthorized error: Bad credentials
2021-02-19 19:06:13.090 WARN 10048 --- [nio-8080-exec-4] o.s.s.c.bcrypt.BCryptPasswordEncoder : Encoded password does not look like BCrypt
2021-02-19 19:06:13.091 ERROR 10048 --- [nio-8080-exec-4] c.b.s.security.jwt.AuthEntryPointJwt : Unauthorized error: Bad credentials