스프링 부트 백엔드 개발 강좌, 데이터베이스, 그림으로 이해하는 프로젝트

안녕하세요! 오늘은 스프링 부트를 활용한 백엔드 개발 강좌를 진행하겠습니다. 이 강좌에서는 스프링 부트의 기본 개념부터 시작하여 데이터베이스 연동, REST API 개발, 그리고 마지막으로 그림을 통해 프로젝트 구조를 이해하는 방법까지 자세히 살펴보겠습니다.

1. 스프링 부트란?

스프링 부트(Spring Boot)는 자바 기반의 스프링 프레임워크를 더욱 간편하게 사용할 수 있도록 돕는 프레임워크입니다. 개발자가 애플리케이션을 신속하게 구축할 수 있도록 지원하며, 복잡한 설정 없이도 실행 가능한 Spring 어플리케이션을 만들 수 있게 해줍니다.

스프링 부트의 주요 특징은 다음과 같습니다:

  • 자동 설정: Spring 설정을 자동으로 구성합니다.
  • 독립 실행형 애플리케이션: JAR 파일로 패키징하여 쉽게 배포하고 실행할 수 있습니다.
  • 생산 준비 완료: 외부 설정 기능과 모니터링 메트릭스를 제공합니다.
  • 스타터 의존성: 필요한 의존성을 간편하게 추가할 수 있도록 도와줍니다.

2. 개발 환경 설정

스프링 부트를 사용하기 위해서는 Java Development Kit (JDK)를 설치하고, IDE(통합 개발 환경)를 선택해야 합니다. 본 강좌에서는 IntelliJ IDEA를 사용하겠습니다.

2.1 JDK 설치

JDK는 Oracle 공식 웹사이트나 OpenJDK를 통해 다운로드할 수 있습니다. 설치 후에는 PATH 환경 변수를 설정하여 JDK를 사용할 수 있도록 해야 합니다.

2.2 IntelliJ IDEA 설치

IntelliJ IDEA는 JetBrains에서 제공하는 IDE입니다. Community Edition은 무료로 제공되며, 스프링 부트 개발에 적합합니다. 공식 웹사이트에서 다운로드 후 설치합니다.

3. 스프링 부트 프로젝트 생성

이제 새로운 스프링 부트 프로젝트를 생성해봅시다. IntelliJ IDEA에서 “New Project”를 클릭하고, “Spring Initializr”를 선택합니다.

3.1 프로젝트 설정

다음과 같은 정보를 입력합니다:

  • Group: com.example
  • Artifact: demo
  • Name: demo
  • Description: Demo project for Spring Boot
  • Package name: com.example.demo
  • Packaging: Jar
  • Java: 11

그 다음, “Dependencies”에서 “Spring Web”, “Spring Data JPA”, “H2 Database”를 추가합니다.

4. 데이터베이스와의 연동

스프링 부트는 다양한 데이터베이스와 쉽게 연동할 수 있도록 지원합니다. 본 강좌에서는 H2 데이터베이스를 사용하여 간단한 CRUD 애플리케이션을 만들어보겠습니다.

4.1 H2 데이터베이스 설정

H2 데이터베이스는 인메모리 데이터베이스로, 프로젝트의 src/main/resources/application.properties 파일에 다음을 추가하여 설정합니다:

spring.datasource.url=jdbc:h2:mem:testdb
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=sa
spring.datasource.password=
spring.h2.console.enabled=true

4.2 Entity 클래스 생성

이제 데이터베이스와 매핑할 Entity 클래스를 생성합니다. “model” 패키지를 만들고, 예를 들어 User 클래스를 아래와 같이 작성합니다:

package com.example.demo.model;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String email;

    // Getters and Setters
}

4.3 Repository 인터페이스 생성

스프링 데이터 JPA를 사용하여 데이터베이스와 상호작용하기 위해 Repository 인터페이스를 생성합니다. ‘repository’ 패키지를 만들고 다음과 같이 인터페이스를 작성합니다:

package com.example.demo.repository;

import com.example.demo.model.User;
import org.springframework.data.jpa.repository.JpaRepository;

public interface UserRepository extends JpaRepository {
}

4.4 Service 클래스 생성

비즈니스 로직을 처리하기 위해 Service 클래스를 생성합니다. ‘service’ 패키지를 만들고 UserService 클래스를 아래와 같이 작성합니다:

package com.example.demo.service;

import com.example.demo.model.User;
import com.example.demo.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class UserService {

    @Autowired
    private UserRepository userRepository;

    public List findAll() {
        return userRepository.findAll();
    }

    public User save(User user) {
        return userRepository.save(user);
    }
}

4.5 Controller 클래스 생성

HTTP 요청을 처리하기 위해 Controller 클래스를 만듭니다. ‘controller’ 패키지를 만들고 UserController 클래스를 작성합니다:

package com.example.demo.controller;

import com.example.demo.model.User;
import com.example.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("/users")
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping
    public List getAllUsers() {
        return userService.findAll();
    }

    @PostMapping
    public User createUser(@RequestBody User user) {
        return userService.save(user);
    }
}

5. RESTful API의 이해

이제 스프링 부트를 이용한 RESTful API를 이해해보겠습니다. REST는 Representational State Transfer의 약자로, 웹 기반의 아키텍처 스타일입니다. RESTful API는 HTTP 요청을 통해 자원을 생성, 읽기, 수정 및 삭제하는 방식으로 작동합니다.

5.1 HTTP 메소드

RESTful API는 다음과 같은 HTTP 메소드를 사용합니다:

  • GET: 자원의 조회
  • POST: 자원의 생성
  • PUT: 자원의 수정
  • DELETE: 자원의 삭제

5.2 JSON 데이터

RESTful API에서 데이터를 전송하기 위해 일반적으로 JSON(JavaScript Object Notation) 형식을 사용합니다. JSON은 가볍고 사람이 읽기 쉬운 데이터 포맷으로, 웹 애플리케이션에서 널리 사용됩니다.

6. 그림으로 이해하는 프로젝트 구조

이제까지의 내용을 바탕으로 프로젝트 구조를 그려보도록 하겠습니다. 다음은 전반적인 프로젝트 구조입니다:

demo
├── src
│   ├── main
│   │   ├── java
│   │   │   └── com.example.demo
│   │   │       ├── controller
│   │   │       │   └── UserController.java
│   │   │       ├── model
│   │   │       │   └── User.java
│   │   │       ├── repository
│   │   │       │   └── UserRepository.java
│   │   │       └── service
│   │   │           └── UserService.java
│   │   └── resources
│   │       └── application.properties
└── pom.xml

7. 결론

이번 강좌에서는 스프링 부트를 사용한 백엔드 개발의 기초를 배우고, 데이터베이스와 연동하여 간단한 RESTful API를 구현하는 방법을 알아보았습니다. 스프링 부트는 강력한 기능을 가진 프레임워크이므로, 추가적인 학습을 통해 더 다양한 기능을 활용해 보시길 권장합니다.

여기서 멈추지 말고, 다양한 프로젝트에 도전해보세요! 여러분의 개발 여정을 응원합니다!