Backend
[스프링 핵심 원리 이해] 스코프와 Provider
햣둘
2025. 2. 18. 07:40
첫 번째 해결 방법은 앞서 배운 Provider를 사용하는 것이다.
간단히 ObjectProvider를 사용해보자.
LogDemoController
package hello.core.web;
import hello.core.common.MyLogger;
import jakarta.servlet.http.HttpServletRequest;
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;
@Controller
@RequiredArgsConstructor
public class LogDemoController {
private final LogDemoService logDemoService;
private final ObjectProvider<MyLogger> myLoggerProvider;
@RequestMapping("log-demo")
@ResponseBody
public String logDemo(HttpServletRequest request) {
String requestURL = request.getRequestURL().toString();
MyLogger myLogger = myLoggerProvider.getObject();
myLogger.setRequestURL(requestURL);
myLogger.log("controller test");
logDemoService.logic("testId");
return "OK";
}
}
main() 메서드로 스프링을 실행하고, 웹 브라우저에 http://localhost:8080/log-demo를 입력하자.
드디어 잘 작동하는 것을 확인할 수 있다.
[de288960-1b18-4117-9699-8bb832485353] request scope ban create:hello.core.common.MyLogger@24825cf6
[de288960-1b18-4117-9699-8bb832485353][http://localhost:8080/log-demo] controller test
[de288960-1b18-4117-9699-8bb832485353][http://localhost:8080/log-demo] service id = testId
[de288960-1b18-4117-9699-8bb832485353] request scope ban close:hello.core.common.MyLogger@24825cf6
[a9b82521-859d-444d-ad3e-2248c0f932d4] request scope ban create:hello.core.common.MyLogger@764013f0
[a9b82521-859d-444d-ad3e-2248c0f932d4][http://localhost:8080/log-demo] controller test
[a9b82521-859d-444d-ad3e-2248c0f932d4][http://localhost:8080/log-demo] service id = testId
[a9b82521-859d-444d-ad3e-2248c0f932d4] request scope ban close:hello.core.common.MyLogger@764013f0
ObjectProvider 덕분에 ObjectProvider.getObject()를 호출하는 시점까지 request scope 빈의 생성을 지연할 수 있다.
ObjectProvider.getObject()를 호출하는 시점에는 HTTP 요청이 진행 중이므로 request scope 빈의 생성이 정상 처리 된다.
ObjectProvider.getObject()를 LogDemoController, LogDemoService에서 각각 한 번씩 따로 호출해도 같은 HTTP 요청이면 같은 스프링 빈이 반환된다! -> 내가 직접 이걸 구분하려면 얼마나 힘들까ㅠㅠ...
이 정도에서 끝내도 될 것 같지만 개발자들의 코드 몇 자를 더 줄이려는 욕심은 끝이 없다.
To be continued~