50% OFF Plus
--:--:--
¡Obtener!

Registro de usuarios en API REST

Avanzado
SpringBoot
SpringBoot
Actualizado: 13/06/2025

¡Desbloquea el curso de SpringBoot completo!

IA
Ejercicios
Certificado
Entrar

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 Plus

En 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.

Progreso guardado
Asistente IA
Ejercicios
Iniciar sesión gratis

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

⭐⭐⭐⭐⭐
4.9/5 valoración