첫번째 해결방안은 Provider를 사용하는 것이다.
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;
@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";
}
}
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 id) {
MyLogger myLogger = myLoggerProvider.getObject();
myLogger.log("service id =" + id);
}
}
[fa840c5d-73c3-41d8-867b-379ad034f824] request scope bean create:hello.core.common.MyLogger@52364add
[fa840c5d-73c3-41d8-867b-379ad034f824][http://localhost:8080/log-demo] controller test
[fa840c5d-73c3-41d8-867b-379ad034f824][http://localhost:8080/log-demo] service id =testId
[fa840c5d-73c3-41d8-867b-379ad034f824] request scope bean close:hello.core.common.MyLogger@52364add
잘 동작하는 것을 볼 수있다.
ObjectProvider 덕분에 objectProvider.getObject()를 호출하는 시점까지 request scope 빈의 생성을 지연 할 수 있다.
objectProvider.getObject()를 호출하는 시점에는 HTTP 요청이 진행중이므로 request 빈의 생성이 정상 처리된다.
objectProvider.getObject()를 LogDEmoController, LogDemoService에서 각각 한번씩 따로 호출해도 같은 HTTP 요청이면 같은 스프링 빈이 반환된다.
'웹프로그래밍 > Spring 핵심 원리' 카테고리의 다른 글
54. 스코프와 프록시 (0) | 2021.10.14 |
---|---|
52. request 스코프 예제 만들기 (0) | 2021.10.14 |
51. 웹 스코프 (0) | 2021.10.14 |
50. 프로토타입 스코프 - 싱글톤 빈과 함께 사용시 Provider로 문제 해결 (0) | 2021.09.09 |
49. 프로토타입 스코프 - 싱글톤 빈과 사용시 문제점 (0) | 2021.09.01 |