SpringBoot
Tutorial SpringBoot: Login de usuarios
Spring Boot login: implementación y seguridad. Aprende a implementar un sistema de login seguro en Spring Boot con ejemplos prácticos y detallados.
Aprende SpringBoot y certifícateIntroducción
Poder autenticar usuarios con un método de login desde un controlador REST en Spring Boot.
La autenticación se basará en crear un token JWT.
Para ello es necesaria la dependencia jjwt en el pom.xml:
<!-- https://mvnrepository.com/artifact/io.jsonwebtoken/jjwt-api -->
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt-api</artifactId>
<version>0.12.5</version>
</dependency>
<!-- https://mvnrepository.com/artifact/io.jsonwebtoken/jjwt-impl -->
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt-impl</artifactId>
<version>0.12.5</version>
</dependency>
<!-- https://mvnrepository.com/artifact/io.jsonwebtoken/jjwt-jackson -->
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt-jackson</artifactId>
<version>0.12.5</version>
</dependency>
Crear método login en controlador
Primero creamos un record Login
para recibir los datos del frontend con las credenciales del usuario:
public record Login(
String email,
String password
) {
}
Creamos el record Token
para la respuesta del login:
public record Token(
String token
) {
}
Crear método login en un controlador REST:
@PostMapping("users/login")
public Token login(@RequestBody Login login) {
if (!this.userRepository.existsByEmail(login.email())) {
throw new NoSuchElementException("User not found");
}
User user = this.userRepository.findByEmail(login.email()).orElseThrow();
if (!passwordEncoder.matches(login.password(), user.getPassword())){
throw new RuntimeException("Credenciales incorrectas");
}
// JWT Json Web Token: jwt.io
// Generar token de acceso: eyJhbGciOiJIUzI1NiIsIn......
// Generar el token: https://github.com/jwtk/jjwt?tab=readme-ov-file#creating-a-jwt
Date issuedDate = new Date();
long nextWeekMillis = TimeUnit.DAYS.toMillis(7);
Date expirationDate = new Date(issuedDate.getTime() + nextWeekMillis);
byte[] key = Base64.getDecoder().decode("FZD5maIaX04mYCwsgckoBh1NJp6T3t62h2MVyEtdo3w="); // Clave secreta
String token = Jwts.builder()
// id del usuario
.subject(String.valueOf(user.getId()))
// La clave secreta para firmar el token y saber que es nuestro cuando lleguen las peticiones del frontend
.signWith(Keys.hmacShaKeyFor(key))
// Fecha emisión del token
.issuedAt(issuedDate)
// Fecha de expiración del token
.expiration(expirationDate)
// información personalizada: rol, username, email, avatar...
.claim("role", user.getRole())
.claim("email", user.getEmail())
//.claim("avatar", user.getAvatarUrl())
// Construye el token
.compact();
return new Token(token);
}
Partes del método:
userRepository.existsByEmail(login.email())
comprueba que el usuario existe.userRepository.findByEmail
extrae el usuario de base de datos.passwordEncoder.matches(login.password(), user.getPassword())
se verifica la contraseña del login con la contraseña de la base de datos.Jwts.builder()
genera un token JWT utilizando una clave secreta.
Por último, se devuelve el token.
Verificar login desde postman
Desde postman enviamos un email y password de un usario que tengamos en base de datos:
Ejemplo del token generado en la respuesta:
eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiIyMTUiLCJpYXQiOjE3MTMzNzExMjcsImV4cCI6MTcxMzk3NTkyNywicm9sZSI6IkFETUlOIiwiZW1haWwiOiJhZG1....
Opcional: se puede decodificar el token desde la página jwt.io:
Verificar login desde frontend
En un frontend como Angular podríamos tener un formulario de login que envíe los datos por POST al controlador y reciba el token:
Con esto ya tenemos el token JWT en el frontend y podríamos guardarlo en el localStorage
.
Ejercicios de esta lección Login de usuarios
Evalúa tus conocimientos de esta lección Login de usuarios con nuestros retos de programación de tipo Test, Puzzle, Código y Proyecto con VSCode, guiados por IA.
CRUD Customers Spring MVC + Spring Data JPA
Backend API REST con Spring Boot
Controladores Spring REST
Crear entidades JPA
Controladores Spring MVC
Asociaciones de entidades JPA
Inyección de dependencias
Consultas JPQL
Servicios en Spring
Todas las lecciones de SpringBoot
Accede a todas las lecciones de SpringBoot y aprende con ejemplos prácticos de código y ejercicios de programación con IDE web sin instalar nada.
Introducción A Spring Boot
Introducción Y Entorno
Spring Boot Starters
Introducción Y Entorno
Inyección De Dependencias
Introducción Y Entorno
Controladores Spring Mvc
Spring Mvc Con Thymeleaf
Vista En Spring Mvc Con Thymeleaf
Spring Mvc Con Thymeleaf
Controladores Spring Rest
Spring Mvc Con Thymeleaf
Open Api Y Cómo Agregarlo En Spring Boot
Spring Mvc Con Thymeleaf
Servicios En Spring
Spring Mvc Con Thymeleaf
Clientes Resttemplate Y Restclient
Spring Mvc Con Thymeleaf
Rxjava En Spring Web
Spring Mvc Con Thymeleaf
Crear Entidades Jpa
Spring Data Jpa
Asociaciones De Entidades Jpa
Spring Data Jpa
Repositorios Spring Data
Spring Data Jpa
Métodos Find En Repositorios
Spring Data Jpa
Inserción De Datos
Spring Data Jpa
Actualizar Datos De Base De Datos
Spring Data Jpa
Borrar Datos De Base De Datos
Spring Data Jpa
Consultas Jpql Con @Query En Spring Data Jpa
Spring Data Jpa
Api Query By Example (Qbe)
Spring Data Jpa
Api Specification
Spring Data Jpa
Repositorios Reactivos
Spring Data Jpa
Testing Unitario De Componentes Y Servicios
Testing Con Spring Test
Testing De Repositorios Spring Data Jpa
Testing Con Spring Test
Testing Controladores Spring Mvc Con Thymeleaf
Testing Con Spring Test
Testing Controladores Rest Con Json
Testing Con Spring Test
Testing De Aplicaciones Reactivas Webflux
Testing Con Spring Test
Testing De Seguridad Spring Security
Testing Con Spring Test
Testing Con Apache Kafka
Testing Con Spring Test
Introducción A Spring Security
Seguridad Con Spring Security
Seguridad Basada En Formulario En Mvc Con Thymeleaf
Seguridad Con Spring Security
Registro De Usuarios
Seguridad Con Spring Security
Login De Usuarios
Seguridad Con Spring Security
Verificar Token Jwt En Peticiones
Seguridad Con Spring Security
Seguridad Jwt En Api Rest Spring Web
Seguridad Con Spring Security
Seguridad Jwt En Api Rest Reactiva Spring Webflux
Seguridad Con Spring Security
Autenticación Y Autorización Con Anotaciones
Seguridad Con Spring Security
Introducción A Spring Webflux
Reactividad Webflux
Spring Data R2dbc
Reactividad Webflux
Controlador Rest Reactivo Basado En Anotaciones
Reactividad Webflux
Controlador Rest Reactivo Funcional
Reactividad Webflux
Operadores Reactivos Básicos
Reactividad Webflux
Operadores Reactivos Avanzados
Reactividad Webflux
Cliente Reactivo Webclient
Reactividad Webflux
Introducción E Instalación De Apache Kafka
Mensajería Asíncrona
Crear Proyecto Con Apache Kafka
Mensajería Asíncrona
Creación De Producers
Mensajería Asíncrona
Creación De Consumers
Mensajería Asíncrona
Kafka Streams En Spring Boot
Mensajería Asíncrona
Integración Con Angular
Integración Frontend
Integración Con React
Integración Frontend
Integración Con Vue
Integración Frontend
En esta lección
Objetivos de aprendizaje de esta lección
- Autenticar usuarios
- Verificar contraseña usuario
- Crear token JWT