package hello.hellospring.controller;
import hello.hellospring.service.MemberService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
@Controller
public class MemberController {
private final MemberService memberService;
@Autowired
public MemberController(MemberService memberService) {
this.memberService = memberService;
}
}
생성자(constructor)로 memberservice의 생성자를 만들어준다.
(window 기준 alt+insert 단축키 이용)
@Autowired
스프링 컨테이너에 있는 Member Service, 즉 service파일의 MemberService와 생성자의 memberService와 연결시켜준다.
이것만으로는 memberservice를 찾지 못하여 오류가 발생한다.
컨트롤러 같은 경우는 @controller 등의 annotation으로 스프링이 찾을 수 있지만 memberservice는 순수한 자바 코드로 이루어진 클래스이기 때문에 스프링이 찾을 수가 없다.
따라서 MemberService 클래스 위에 @Service 라는 annotation을 넣어준다.
같은 원리로 구현체인 MemoryMemberRepository 클래스 위에 @Repository를 넣어준다.
MemberController와 MemberService를 이어주었으니 MemberService와 MemoryMemberRepository도 똑같이 @Autowired로 이어준다.
이 과정이 스프링 빈을 등록하는 2가지 방법 중에서 한가지인 컴포넌트 스캔 방식이다. (@Autowired와 같은 annotation 이용)
@Controller, @Service, @Repository를 살펴보면 그 속에 @Component가 붙어있는 것을 확인할 수 있다.
※ @Component 에노테이션이 있으면 스프링 빈으로 자동 등록 된다.
package hello.hellospring;
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();
}
}
=> 현재 가상 시나리오는 '저장소가 정해지지 않아 바뀔 수 있으므로 구현체를 통하여 추후에 바꿀 수 있도록 설계'하였기 때문에 수동으로 스프링 빈으로 등록하여 간단하게 바꿀 수 있도록 설계한다.
※ 스프링 컨테이너, DI 관련된 자세한 내용은 스프링 핵심 원리 강의에서 설명한다.