728x90
반응형
첫번째 해결 방안은 앞서 배운 Provider를 사용하는 것이다.
간단히 ObjectProvider를 사용해보자.
LogDemoController.java
package hello.core.web;
import hello.core.common.MyLogger;
import lombok.RequiredArgsConstructor;
import org.springframework.beans.factory.ObjectProvider;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.servlet.http.HttpServletRequest;
@Controller
@RequiredArgsConstructor
public class LogDemoController {
private final LogDemoService logDemoService;
private final ObjectProvider<MyLogger> myLoggerProvider; // Request가 들어와야 오류가 안나는데 애초에 리퀘스트가 없으니 오류가 났음
// @ResponseBody를 사용하면 넘겨온 문자를 그대로 보낼 수 있다.
@RequestMapping("log-demo")
@ResponseBody
public String logDemo(HttpServletRequest request) {
MyLogger myLogger = myLoggerProvider.getObject();
String requestURL = request.getRequestURL().toString();
myLogger.setRequestURL(requestURL);
myLogger.log("controller test");
logDemoService.logic("testId");
return "OK";
}
}
LogDemoService.java
package hello.core.web;
import hello.core.common.MyLogger;
import lombok.RequiredArgsConstructor;
import org.springframework.beans.factory.ObjectProvider;
import org.springframework.stereotype.Service;
@Service
@RequiredArgsConstructor
public class LogDemoService {
private final ObjectProvider<MyLogger> myLoggerProvider;
public void logic(String testId) {
MyLogger myLogger = myLoggerProvider.getObject();
myLogger.log("service id = " + testId);
}
}
'main()' 메서드로 스프링을 실행하고, 웹 브라우저에 'http://localhost:8080/log-demo'를 입력하자
드디어 잘 작동하는 것을 확인할 수 있다.
[10607cd6-c5b9-4c01-8b72-6ae4277b89dc] request scope bean create : hello.core.common.MyLogger@1510a3ee
[10607cd6-c5b9-4c01-8b72-6ae4277b89dc][http://localhost:8080/log-demo] controller test
[10607cd6-c5b9-4c01-8b72-6ae4277b89dc][http://localhost:8080/log-demo] service id = testId
[10607cd6-c5b9-4c01-8b72-6ae4277b89dc] request scope bean close : hello.core.common.MyLogger@1510a3ee
- 'ObjectProvider' 덕분에 'ObjectProvider.getObject()'를 호출하는 시점까지 request scope 빈의 생성을 지연할 수 있다.
- 'ObjectProvider.getObject()'를 LogDemoController, LogDemoService에서 각각 한번씩 따로 호출해도 같은 HTTP 요청이면 같은 스프링 빈이 반환된다. => 직접 이걸 구분하지 않아도 된다
728x90
반응형
'스프링 > 핵심 원리' 카테고리의 다른 글
[Spring] 스코프와 프록시 (2) | 2022.03.07 |
---|---|
[Spring] request 스코프 예제 만들기 (0) | 2022.03.07 |
[Spring] 웹 스코프 (0) | 2022.03.07 |
[Spring] 프로토타입 스코프 - 싱글톤 빈과 함께 사용 시 Provider로 문제 해결 (0) | 2022.03.06 |
[Spring] 프로토타입 스코프 - 싱글톤 빈과 함께 사용시 문제점 (0) | 2022.03.06 |
댓글