Registro de usuarios en API REST

Avanzado
SpringBoot
SpringBoot
Actualizado: 13/06/2025

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. 

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:

Alan Sastre - Autor del tutorial

Alan Sastre

Ingeniero de Software y formador, CEO en CertiDevs

Ingeniero de software especializado en Full Stack y en Inteligencia Artificial. Como CEO de CertiDevs, SpringBoot es una de sus áreas de expertise. Con más de 15 años programando, 6K seguidores en LinkedIn y experiencia como formador, Alan se dedica a crear contenido educativo de calidad para desarrolladores de todos los niveles.

Más tutoriales de SpringBoot

Explora más contenido relacionado con SpringBoot y continúa aprendiendo con nuestros tutoriales gratuitos.

Aprendizajes de esta lección

  • Registro de nuevas cuentas de usuario
  • Cifrar contraseña
  • Verificar email ocupado en creación de usuarios
  • Verificar creación de usuarios

Cursos que incluyen esta lección

Esta lección forma parte de los siguientes cursos estructurados con rutas de aprendizaje