符合中小企业对网站设计、功能常规化式的企业展示型网站建设
本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...
商城网站建设因基本功能的需求不同费用上面也有很大的差别...
手机微信网站开发、微信官网、微信商城网站...
这篇文章主要介绍了spring如何根据controller中接收请求参数不同service,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
创新互联服务项目包括科尔沁左翼网站建设、科尔沁左翼网站制作、科尔沁左翼网页制作以及科尔沁左翼网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,科尔沁左翼网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到科尔沁左翼省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
附controller的分类:
正文
我的解决办法是,使用“生产线工人工作能力自己掂量机制”来解决,这名字我自己起的,实际上就是想要实现按参数选择走哪个 service 实现,可以一次性把所有 service 实现全都注入进来,然后依次请求,同时在每个 service 实现中写一套规则判别方法,判断当前请求自己是不是能够处理,如果能够处理,则进入处理方法,若自己没有处理能力,则退出,让请求走到其他 service 做同样的判断。形象点,可以想象一下,在一条生产线的传送带上传送着不同品类的待加工的元部件,有若干工人排列在传送带旁边,每个工人只会加工某一种元件,那么,当传送带上的元件传送到自己面前时,需要判断一下,自己有没有处理这个元件的能力(掂量一下自己的能力),若有,取过来处理,若没有,放过去让别人走流程。
理解了其中逻辑,我们就来看代码吧(片段):
public interface ServiceProvider { // 掂量一下自己有没有能力加工当前的元件(也就是Request),能就返回 true 不能返回 false boolean support(Request request); // 具体加工元件的逻辑 Response execute(Request request); }
@Service public class ServiceImpl implements Service { // 注入一系列 service 数量不定 https://stackoverflow.com/questions/2153298/how-to-autowire-factorybean @Resource(name = "serviceProviders") private ListserviceProviders; @Override public List execute(Request request) { return serviceProviders // 循环每个 service TODO 现在时间复杂度为 O(n) 可以尝试优化为 O(logn) .stream() .filter(serviceProvider -> serviceProvider.support(request)) // 按加工能力过滤 .map(serviceProvider -> serviceProvider.execute(request)) // 执行 service 得 execute 方法 .collect(Collectors.toList()); } }
这里有一点需要解释一下,在上面第二段代码中,有这么一段:
@Resource(name = "serviceProviders") private ListserviceProviders;
这里是使用 spring 中的 FactoryBean 机制实现的,可以简单的这样理解 FactoryBean :FactoryBean 是生成普通 Bean 的 Bean,当注入 FactoryBean 时,默认注入的是其生产出来的所有普通 Bean,而不是它自己。
在上边代码中,注入的名为 serviceProviders 的这个 Bean,实际上是这样定义出来的:
@Component("serviceProviders") // 注意这个 Bean 的名字,当其他 Bean 中注入这个 Bean 时,会注入 createInstance() 返回类型的 Bean,而不是其自身的类型 ServiceProviderFactoryBean public class ServiceProviderFactoryBean extends AbstractFactoryBean> implements ApplicationContextAware { private ApplicationContext applicationContext; @Override public Class> getObjectType() { return List.class; } @Override protected List
createInstance() { // 扫描所有 provider 并从 Bean 容器取出放入 list Reflections reflections = new Reflections(ServiceProvider.class.getPackage().getName()); return reflections .getSubTypesOf(ServiceProvider.class) .stream() .map((Function , ServiceProvider>) serviceProviderClass -> applicationContext.getBean(serviceProviderClass)) .collect(Collectors.toList()); } @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { this.applicationContext = applicationContext; } }
通过这样的设计,就完成了我们的需求,实际上我们等于把思路反转了一下,从想尽办法控制注入到不做控制,一股脑全部注入进去,然后按规则过滤。有时候,其实遇到一条思路走不通的时候,可以反过来想想,也许就会走通。
感谢你能够认真阅读完这篇文章,希望小编分享的“spring如何根据controller中接收请求参数不同service”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!