栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

从Java 8函数创建请求范围的Bean

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

从Java 8函数创建请求范围的Bean

您引用的答案有所不同:它在声明的bean和注入的bean中使用完全相同的泛型类型:

@Beanpublic Function<String, Thing> thingFactory() {    return name -> thing(name); // or this::thing}

和:

@Autowiredprivate Function<String, Thing> thingFactory;

使用泛型类型是否有问题?我怎么了

是。您要注入具有此签名的bean:

Function<CheckRequest, RequestWrapper<CheckRequest, CheckResponse>> requestWrapperFactory;

但是你用这个签名声明了一个bean:

Function<? extends baseRequest, RequestWrapper<? extends baseRequest, ? extends baseResponse>>

这里 :

@Beanpublic Function<? extends baseRequest, RequestWrapper<? extends baseRequest, ? extends baseResponse>> requestWrapperFactory() {    return request -> requestWrapper(request);}

bean声明和连接的bean中使用的泛型必须相同,才能在依赖项注入方面进行匹配。

因此,只需在双方声明相同的类型。

所以这意味着没有办法使用泛型来配置bean?因为我也想将bean创建也用于CancelRequest(更新后的答案)。因此,我必须为所有类型的baseRequest创建一个Bean。

对于

@RequestScope
bean,从理论上讲,使用泛型不会造成任何问题,因为Bean是在每个请求时创建的,并且不会重用,但是我认为for的泛型功能
@Bean
没有什么区别,因此考虑一般情况(单作用域)完美匹配是避免类型安全和一致性问题所必需的。


编辑后:

我更新了第一部分以与您的更改保持一致。

现在,您的要求是声明一个函数,该函数将向客户端返回具有由客户端指定的通用类型的原型Bean。
那是可能的。但是,要使其简洁,就不应使用两个bean:一个用于工厂(单例),另一个用于创建

RequestWrapper
对象(原型)。
由于工厂bean不允许客户端指定通用类型,因此您将不得不执行不希望的取消广播。
您还应该替换为
@RequestScope
@Scope(value=ConfigurableBeanFactory.SCOPE_PROTOTYPE)
因为请求范围内的Bean不允许像配置类中的singleton和prototypeBean那样可配置。
例如,使用参数或通配符不能很好地工作。

因此,我们的想法是声明一个原型bean,其返回的泛型类型取决于参数和目标。
关于

RequestConfig
,现在最好将其命名为
RequestFactory
它的角色。

@Configurationpublic class RequestFactory {    @Bean    @Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE)    public <T extends baseRequest, U extends baseResponse> RequestWrapper<T, U> requestWrapper( T request) {        RequestWrapper<T, U> requestWrapper = new RequestWrapper<>(request);        return requestWrapper;    }}

在控制器中注入

@Configuration
bean
requestFactory

private RequestFactory requestFactory; // Changepublic CheckRequestController(        RequestService<CheckRequest, CheckResponse> checkRequestServiceImpl,        RequestConfig requestConfig) {    this.checkRequestServiceImpl = checkRequestServiceImpl;    this.requestFactory = requestFactory; // Change}

现在,您可以在需要

RequestWrapper
时注入所需的原型bean :

@PostMapping(value = "/cancel", consumes = { MediaType.TEXT_XML_VALUE,        MediaType.MULTIPART_FORM_DATA_VALUE }, produces = MediaType.TEXT_XML_VALUE)public ResponseEntity<CancelResponse> CancelRequest(        @RequestBody(required = true) CancelRequest cancelRequest) {    RequestWrapper<CheckRequest, CheckResponse> requestWrapper =     requestFactory.requestWrapper(cancelRequest);     //...    return new ResponseEntity<CancelResponse>(requestWrapper.getResponse(), HttpStatus.OK);}

现在进行测试,看起来可以正常工作。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/594828.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号