Mira la lección en vídeo
Accede al vídeo completo de esta lección y a más contenido exclusivo con el Plan Plus.
Desbloquear Plan PlusEn esta lección se va a configurar un método register en un controlador REST de Spring Boot que permita registrar nuevas cuentas de usuario.
Para este ejemplo se presupone que tenemos ya una aplicación Spring Boot con una base de datos SQL y con una entidad User.
Agregar dependencia Spring Security
En el archivo pom.xml agregar la dependencia:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
Crear clase SecurityConfig
En esta clase se configura la seguridad a nivel global de toda la aplicación de Spring Boot.
Empezamos configurando el bean de PasswordEncoder
utilizando el algoritmo bcrypt.
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
@Configuration
public class SecurityConfig {
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
}
Crear método register en controlador
Primero se crea un record Register
para recibir los datos de frontend:
public record Register(
String email,
String password
) {
}
En un controlador con @RestController
como UserController
o AuthController
se crea un método para el registro de usuarios que recibe un objeto Register y primero comprueba si el email está disponible.
Después se crea el objeto User con la contraseña cifrada y se almacena en base de datos:
@CrossOrigin("*") // Permitir acceso desde cualquier dominio desde el exterior
@RestController
@AllArgsConstructor
@Slf4j
public class UserController {
private final UserRepository userRepository;
private final PasswordEncoder passwordEncoder;
@PostMapping("users/register")
public void register(@RequestBody Register register) {
if (this.userRepository.existsByEmail(register.email())){
throw new RuntimeException("Email ocupado"); // Lanzar excepción personalizada
}
User user = User.builder()
.email(register.email())
.password(passwordEncoder.encode(register.password())) // contraseña cifrada
.role(Role.USER)
.build();
this.userRepository.save(user);
}
}
Verificar creación de nuevo usuario
Desde frontend o postman enviamos un nuevo usuario al endpoint /users/register
y verificamos que se crea un usuario con contraseña cifrada.
Guarda tu progreso
Inicia sesión para no perder tu progreso y accede a miles de tutoriales, ejercicios prácticos y nuestro asistente de IA.
Más de 25.000 desarrolladores ya confían en CertiDevs
Ejemplo desde postman:
Debemos verificar que el status de la respuesta sea correcta.
Una vez creado el usuario, verificar la base de datos:
O también es posible realizar un registro desde un frontend como por ejemplo en Angular:
Aprendizajes de esta lección de SpringBoot
- Registro de nuevas cuentas de usuario
- Cifrar contraseña
- Verificar email ocupado en creación de usuarios
- Verificar creación de usuarios
Completa este curso de SpringBoot y certifícate
Únete a nuestra plataforma de cursos de programación y accede a miles de tutoriales, ejercicios prácticos, proyectos reales y nuestro asistente de IA personalizado para acelerar tu aprendizaje.
Asistente IA
Resuelve dudas al instante
Ejercicios
Practica con proyectos reales
Certificados
Valida tus conocimientos
Más de 25.000 desarrolladores ya se han certificado con CertiDevs