Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/afa-farkhod/springboot-jwt-authentication-authorization

JWT authentication and authorization implementation in Spring Boot 3.0 application
https://github.com/afa-farkhod/springboot-jwt-authentication-authorization

authentication authorization java jwt jwt-authentication postman spring-boot spring-security

Last synced: about 2 months ago
JSON representation

JWT authentication and authorization implementation in Spring Boot 3.0 application

Awesome Lists containing this project

README

        

# SpringBoot-JWT-Authentication-Authorization
JWT authentication and authorization implementation in Spring Boot 3.0 application

## [Implementation]()

- The implementation is about the JWT authentication and authorization in Spring Boot 3.0 application using Spring Security 6 and MySQL database to store user credentials. To secure the application and protect endpoints JSON Web Tokens were used. In the beginning we set the MySQL database and create user table to store user's credentials. Then we configure Spring Security to use JWT and define security rules for application. In the end, we test the application by building simple API and using Postman to send authenticated requests.


Image

## Run the Demonstration

- We start the Spring application:


Image

- We can see that table was created:


Image

- Now we register new user to our Database by sending post request with `Postman` client:

image

- Then we can see that our new user is successfully registered to Database and in fact as we can see password is encoded so that no one except the owner can know the real password:

![image](https://github.com/af4092/SpringBoot-JWT-Authentication-Authorization/assets/24220136/5097d213-a9c7-4762-a8f4-45eb4a8dda06)

- And on Postman Client side we `Authorization JWT token` as the proof of successful registration to Database:

image

- And now, after registering the user to Database, we try to login with the existing email and password, for this we send request through Postman client to server with the email and password information:

image

- And as the result we get our token back:

image

## [Troubleshooting](https://stackoverflow.com/questions/39632667/how-do-i-remove-the-process-currently-using-a-port-on-localhost-in-windows)

- Sometimes when we run the Spring application which in default listens to `port:8080` we get the `port in use` error. In this case we open the terminal and check port: 8080 and kill the PID which is listening to port.


Image

![image](https://github.com/af4092/SpringBoot-JWT-Authentication-Authorization/assets/24220136/52596d27-dd2c-4688-995f-043ca6ec7240)