기본 콘텐츠로 건너뛰기

[Spring] DI 1탄 - DI개요

DI(Dependency Injection)란 무엇인가?

기능을 실행하기 위해 다른 클래스를 필요로 할 때 이를 의존한다 한다.


public class UserServiceImpl implements UserService {
      private final UserRepository userRepository;
      private final PasswordEncoder passwordEncoder;

      public UserServiceImpl(DataSource dataSource) {
          this.userRepository = new JdbcUserRepository(dataSource);
          this.passwordEncoder = new BCryptPasswordEncoder();
      }
      @Override
      public void register(User user, String rawPassword) {

      }
}


생성자에서 위와 같이 초기화를 직접 할당하게 되면 '클래스간 결합도가 높다'라는 문제가
발생한다. 이는 UserServiceImple을 개발하는 단계에서 의존하는 컴포넌트 클래스가
완성되어 있어야 한다는 의미다.


의존하는 클래스가 아직 개발중이거나 미완성이라면 완벽한 컴포넌트를 구성할 수가 없게 된다.


이런 결합도를 낮추려면 생성자에서 직접생성 대신 생성자의 인수로 받아 할당하는 방법이 있다.
 
public UserServiceImpl(UserRepository userRepository, PasswordEncoder passwordEncoder) {
      this.userRepository = userRepository;
      this.passwordEncoder = passwordEncoder;
}


어떤 클래스가 필요로 하는 컴포넌트를 외부에서 생성한 후, 내부에서 사용 가능하게 만들어주는
과정을 '의존성 주입(DI)'이라 한다.
이런 의존성 주입을 자동으로 처리하는 기반을
'DI컨테이너(=스프링컨테이너 = IoC컨테이너 = 빈컨테이너)'라고 한다.
인스턴스의 스코프 관리도 'DI 컨테이너'가 대신해준다.


DI는 IoC라는 디자인 패턴 중 하나다. 컴포넌트를 구성하는 인스턴스의 생성과 의존 관계의
연결 처리를 해당 소스코드가 아닌 DI컨테이너(IoC 컨테이너)에서 대신하기 때문에 제어가
역전 됬다고 한다.


DI에 의존 객체를 전달하는 방법

크게 생성자 방식과 프로퍼티 설정 방식이 있다. 생성자 방식은 앞에서 예제에 봤고, 프로퍼티 방식을
보면, 객체를 전달 받기 위해 매서드(세터메서드)를 이용한다. setXXX.


DI 컨테이너란 무엇인가?

스프링은 객체를 생성하고 객체를 연결해주는 조립기 역할을 한다.
조립기 기능을 하는 클래스중 하나의 예로 GenericXmlApplicationContex가 있다.
조립기 클래스는 xml등의 정의된 설정 정보를 읽어와 객체를 생성, 연결한 뒤 내부적으로 보관한다.
이런 생성과 보관 떄문에 스프링을 ‘객체 컨테이너’라고도 부른다.
스프링 컨테이너가 생성해 보관하는 객체를 스프링 빈 객체라 부른다.

지금까지 DI에 관해서 간략하게 알아보았다.
프로그램이건 어떤 학문을 배울 땐 용어가 가장 중요한거 같다. 앞으로 중요한 용어에 대해선 노란색으로 색칠해 놓을 테니 이해가 부족하다면 다른 참고자료들을 활용해 꼭 숙지하도록 하자.

댓글

이 블로그의 인기 게시물

[스프링부트2.0 낚시게시판] 01. 프로젝트 생성 및 환경을 세팅해 보자

첫번째. 이클립스에서 프로젝트를 생성해 보자. 빠밤! 1. 이클립스 실행하고 프로젝트 생성하기  - 이클립스 실행 후 File -> New -> Spring Starter Project클릭 ( 부트는 Spring Starter Project로!! )        해당 프로젝트 설정을 본인의 입맛에 맞게? 해주자. 처음엔 저와 똑같이 하는게 삽질(?)의 노고를 덜 수 있으니 저 같은 초보 개발자 분들이나 이제 막 공부를 시작 하셧다면 위와 가이 설정 하는걸 추천.  - New Spring Starter Project Dependencies    - Spring Boot Version : 2.0.2    - Core : DevTools, Security, Lombok 클릭    - Web : web  클릭    - SQL : JPA, H2 클릭    - template Engines : Mstache   --> 타임리프(요즘 회사에서 많이 쓴다고해서)   - 그다음 다음 -> Finish 클릭하게 되면 Maven에 관한 프로젝트가 생성된다.   처음엔 메이븐 디펜던시부분을 받느라 시간이 걸릴수 있다. 프로젝트 구조는 스프링과 별반 차이가 없어 보인다 프로젝트 구조 관련해선 조만간 포스팅 해봐야 겠다. (요즘 책 읽을 시간도 없어서...😂) 두번째. 실행을 해보자.  스프링 부트2.0의 특징은 자체적으로 톰켓이 내장 되어 있어 따로 톰켓을 설정하는 부분이 없어서 아주 매우 편안하게 되었다.    - 실행은 src/main/java 밑에 com.fishing.board 패키지 밑에 FishBoardApplication.java 오른쪽 클릭 후...

[Spring] 웹 개발에 필요한 기본 정보들

이번 시간에는 웹 어플리케이션 개발에 필요한 기본 정보를 알아보려한다. MVC 패턴과 이 내용들을 잘 다룰줄 안다면 기본적인 웹 동작은 구현할 수 있을 것이다. 웹 애플리케이션의 종류 화면으로 응답하는 웹 애플리케이션 웹 페이지 형태로 클라이언트에 응답한다. 데이터로 응답하는 웹 애플리케이션 사용자 인터페이스와 데이터를 분리해서 취급하는 애플리케이션은 JSON or Xml을 사용해 데이터 형태로 클라인언트에 응답한다. 애플리케이션 설정 서블릿 컨테이너 설정 스프링 MVC를 이용해 웹 애플리케이션을 할때 ContextLoaderListener, DispatcherServlet, CharacterEncodingFilter를 서블릿 컨테이너에 등록해야 한다. 애플리케이션 컨텍스트 설정 MessageSource와 PropertySourcePlaceholderConfigurer의 빈 정의도 필요하다. 프런트 컨트롤러 설정 자바 기반설정은 @EnableWebMvc를 추가하면 된다. XML에선 <mvc:annotation-driven>요소룰 추하가면 된다. @Controller 구현 컨트롤러에서 구현하는 처리 내용 선언형 처리 : 메서드 시그니처를 참조해 프런트 컨트롤러가 하는 일 프로그래밍형 처리 : 컨트롤러 클래스의 메서드 안에 하는 일 분류 처리내용 선언형 요청매핑 요청 데이터 취득 입력값 검사 수행 프로그래밍형 입력값 검사 결과 확인 비즈니스 로직 호출 이동 대상 확인 및 데이터 연계 이동 대상 지정 컨트롤러 클래스 작성 @Controller public class WelcomController {   } POJO 클래스에 @Controller를 지정하면 다음 효과를 얻을 수 있다. 컴포넌트 스캔 기능을 사용해 DI 컨테이너에 빈으로 등록할 수 있다. 요청을 처리하는 메...

[자바 웹 프로그래밍]1장 첫번째 양파껍질 벗기기

자바 웹 프로그래밍 Next Step 책을 가지고 스터디를 시작했다. 1장은 학습 방향과 학습법에 관한 얘기인데, 나에게 와 닿은 부분을 남겨본다. 웹 개발자 공부 순서  웹을 처음 접했을 때 어디서부터 어느것 부터 공부해야하고 어떤 책을 봐야할지 매우 막막했던 기억이 있다. 본 책에서는 HTML --> CSS --> 자바스크립트 --> 자바 --> 자바웹프로그래밍 --> DB  이 순서로 학습 방향을 제시하고 있다. 백앤드 개발자로 가고 싶어 Spring 프로젝트를 몇차례 진행한 결론은 자바스크립트의 흐름은 어느정도 알고 있는게 도움이 된다는 결론이다.  다음으로 소프트웨어 학습하는 좋은 방법 몇가지가 나오는데, 그 중 내가 최근에 똑같이 느꼈던 것이 있어 적어본다. '일단 무엇인가 만들어보는 경험을 한 후 이론적인 개념을 학습하고, 다시 다음 단계 경험을 하고 이론적인 개념을 학습하는 과정을 반복하는 것이라 생각한다' 라는 구절이 나오는데, 최근 몇차례 Spring 프로젝트를 하면서, 이론에 대한 대략적인것을 기반으로 수많은 삽질과 성취를 이루고 난 다음, 삽질했던 부분을 책이나 인터넷 자료를 봤을때 부족했던 부분이 '아 이건 이렇게 쓰는거구나' 라는 것이 확실히 느낄 수 있었다. 전에는 무조건 '이론먼저 완벽하게 하고 프로젝트 하자!' 식이었는데 이는 경험상 별로 효과를 보지 못한것 같다(이론 금방 까먹는다.. 왜 써야 되는지 못느껴서). 책을 통한 학습  다음 몇가지 책을 추천했는데, 내가 읽은것과 앞으로 읽어봐야 할것을 나열하겠다. 1. 열혈강의 자바 웹 개발 워크북 - 엄진영  이 책 나에게 웹의 세계로 인도를 해주셧던 엄진영 강사님 책이다. 웹이 어떻게 나왔는지 부터 스트링 사용까지 차례대로 차근차근 따라할 수 있게 아주 잘 설명되고 좋은 소스코드를 제공하고 있다. 웹 처음이라면 반드시 볼것을 추천한다. 2. SQL 첫걸음 3. 코딩을 지탱하는 기술...