

Artifact와 Name을 user-service라고 지어주자. Package name을 Java 컨벤션에 맞게 userservice라고 지어주자.Spring Boot DevTools, Spring Web, MySQL Driver, Spring Data JPA를 선택하자. 이 프로젝트에서는application.properties를 지우고application.yml을 생성했다.
server: port: 8080 spring: datasource: url: jdbc:mysql://localhost:3306/user-db # DB 주소 username: root # DB 계정 password: password # DB 비밀번호 driver-class-name: com.mysql.cj.jdbc.Driver jpa: hibernate: ddl-auto: update show-sql: true

@Entity @Table(name = "users") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long userId; private String email; private String name; private String password; public User() { } public User(String email, String name, String password) { this.email = email; this.name = name; this.password = password; } public Long getUserId() { return userId; } public String getEmail() { return email; } public String getName() { return name; } public String getPassword() { return password; } }
public interface UserRepository extends JpaRepository<User, Long> { }
@RestController @RequestMapping("/users") public class UserController { private final UserService userService; public UserController(UserService userService) { this.userService = userService; } @PostMapping("sign-up") public ResponseEntity<Void> signUp( @RequestBody SignUpRequestDto signUpRequestDto ) { userService.signUp(signUpRequestDto); return ResponseEntity.noContent().build(); } }
public class SignUpRequestDto { private String email; private String name; private String password; public String getEmail() { return email; } public String getName() { return name; } public String getPassword() { return password; } }
@Service public class UserService { private final UserRepository userRepository; public UserService(UserRepository userRepository) { this.userRepository = userRepository; } @Transactional public void signUp(SignUpRequestDto signUpRequestDto) { User user = new User( signUpRequestDto.getEmail(), signUpRequestDto.getName(), signUpRequestDto.getPassword() ); this.userRepository.save(user); } }


