728x90
수동으로 스프링에 등록하는 방법
MemberService와 MemberRepository의 @Service, @Repository, @Autowired 애노테이션을 제거하고 진행한다.
package hello.hellospring;
import hello.hellospring.domain.Member;
import hello.hellospring.repository.MemberRepository;
import hello.hellospring.repository.MemoryMemberRepository;
import hello.hellospring.service.MemberService;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class SpringConfig {
@Bean
public MemberService memberService() {
return new MemberService(memberRepository());
}
@Bean
public MemberRepository memberRepository() {
return new MemoryMemberRepository();
}
}
MemberService와 MemberRepository를 스프링 빈에 등록하고 MemberService는 MemberRepository를 사용하도록 했고 컨트롤러는 MemberService를 Autowired로 연결해주면 된다.
그리고 프로젝트를 실행하면
정상적으로 스프링이 실행된다.
이것이 자바 코드로 직접 스프링 빈을 등록하는 방법이다.
- 과거 XML로 설정하는 방법도 있었지만 실무에서는 거의 사용하지 않는다.
- DI는 필드 주입, setter 주입, 생성자 주입 이렇게 세 가지 방법이 있다. 위에서 진행한 방법은 생성자를 주입하기때문에 생성자 주입이었고, 아래와 같이 필드에 주입하는 방법도 있다. 하지만 필드 주입은 권장하지 않는 방법이다.
// 생성자 주입
@Autowired private final MemberService memberService;
public MemberController(MemberService memberService) {
this.memberService = memberService;
}
// 필드 주입
@Autowired private MemberService memberService;
생성자 주입을 하게 되면 스프링이 실행되어 컨테이너에 올라갈 때 한번만 주입이 되고 끝난다.
setter 주입은 누구든 public 접근을 허용하기 때문에 변경의 가능성이 있어 최근에는 잘 사용되지 않는다.
- 실무에서는 주로 정형화된 컨트롤러, 서비스, 리포지토리 같은 코드는 컴포넌트 스캔을 사용한다. 그리고 정형화되지 않거나, 상황에 따라 구현 클래스를 변경해야 하면 설정을 통해 스프링 빈으로 등록한다.
- @Autowired를 통한 DI는 helloController, MemberService 등과 같이 스프링이 관리하는 객체에서만 동작한다. 스프링 빈으로 등록하지 않고 내가 직접 생성한 객체에서는 동작하지 않는다.
728x90
'스프링 부트 > 스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술' 카테고리의 다른 글
18~23. 스프링 DB 접근 기술 (0) | 2023.03.11 |
---|---|
15. 회원 웹 기능 - 홈 화면 추가 (0) | 2023.03.11 |
13. 컴포넌트 스캔과 자동 의존관계 설정 (0) | 2023.03.11 |
12. 회원 서비스 테스트 (0) | 2023.03.08 |
11. 회원 서비스 개발 (0) | 2023.03.07 |