据我测试,它正在工作。但我不明白它为什么以及如何工作。(我也不确定在生产中使用它是否安全)
这是我的测试代码
@Service
public class SomeService {
private static final Logger logger = LoggerFactory.getLogger(SomeService.class);
private final RequestContext requestContext; // @RequestScope + @Component Bean
public SomeService(RequestContext requestContext) {
this.requestContext = requestContext;
}
public void checkBean() {
logger.info("Singleton Bean: {}, RequestScope Bean: {}", this, this.requestContext);
String clientId = recommendContext.getClientId();
}
}
像下面这样的场景
- 从控制器获取请求
SomeService
由控制器注入- 每个请求都有自己的
RequestContext
Bean - 在控制器中,调用
someService.checkBean()
我认为奇怪的一点是
SomeService
是一个单例 beanRequestContext
被声明为final
变量并且仅由构造函数启动- 但是,它似乎有效。
运行代码的结果如下所示
2021-06-14 09:56:26.010 INFO 23075 --- [nio-8888-exec-1] p.service.SomeService : Singleton Bean: pkgs.service.SomeServiceImpl@3c65ee26, RequestScope Bean: pkgs.context.RequestContext@56867592
2021-06-14 09:56:30.933 INFO 23075 --- [nio-8888-exec-3] p.service.SomeService : Singleton Bean: pkgs.service.SomeServiceImpl@3c65ee26, RequestScope Bean: pkgs.context.RequestContext@73ddb7a4
2021-06-14 09:56:31.687 INFO 23075 --- [nio-8888-exec-4] p.service.SomeService : Singleton Bean: pkgs.service.SomeServiceImpl@3c65ee26, RequestScope Bean: pkgs.context.RequestContext@56b4f7c8
2021-06-14 09:56:32.352 INFO 23075 --- [nio-8888-exec-5] p.service.SomeService : Singleton Bean: pkgs.service.SomeServiceImpl@3c65ee26, RequestScope Bean: pkgs.context.RequestContext@33469287
如您所见,Service 是 Single 并且 RequestContext bean 对于每个请求都是唯一的。我需要解释一下春天里发生了什么
谢谢