Spring的component-scan可配置化
本文是基于Spring4.3.5.RELEASE的版本进行的分析和实践
在Spring的web项目里面, 如果我们需要在类似 applicationContext.xml里面加上
<context:component-scan base-package="${component.scan.package}" />
让base-package可配置, 那应该怎么做呢?
1. 加到Jvm的启动参数里面
比如
-Dcomponent.scan.package=com.example.yours
这里面有两个不方便的地方:
1.多个属性的话, 一个个加启动参数不方便,
2.修改了属性的值,也需要一个个修改对应的启动参数
2. 加到ServletContext里面
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Map.Entry;
import java.util.Properties;
import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import org.springframework.core.io.DefaultResourceLoader;
import org.springframework.core.io.Resource;
import org.springframework.core.io.ResourceLoader;
import org.springframework.web.context.ContextLoaderListener;
public class SingleWebContextLoaderListener extends ContextLoaderListener {
    private static final String DEFAULT_ENCODING = "UTF-8";
    private static final String[] SPRING_PROPERTIES_FILE_NAME = new String[] {"classpath:property1.properties"};
    
	@Override
	public void contextInitialized(ServletContextEvent event) {
	    initPropertySources(event.getServletContext(), SPRING_PROPERTIES_FILE_NAME);
		super.contextInitialized(event);
	}
	
	private void initPropertySources(ServletContext servletContext, String... resourcesPaths) {
	    ResourceLoader resourceLoader = new DefaultResourceLoader();
	    Properties props = new Properties();
        for (String location : resourcesPaths) {
            Resource resource = resourceLoader.getResource(location);
            try (InputStream is = resource.getInputStream()){
                props.load(new InputStreamReader(is, DEFAULT_ENCODING));
            } catch (IOException ex) {
                ex.printStackTrace();
            }
        }
        for(Entry<Object, Object> e : props.entrySet()) {
            servletContext.setInitParameter((String)e.getKey(), (String)e.getValue());
        }
	}
}
然后在web.xml把原来的ContextLoaderListener 替换成SingleWebContextLoaderListener
<listener>
		<listener-class>xx.xx.SingleWebContextLoaderListener</listener-class>
</listener>
当然如果你需要用到 ${}这种变量的话, 别忘了加
<bean          class="org.springframework.context.support.PropertySourcesPlaceholderConfigurer"/>
上面说明的两种方法, 都是比较方便的, 如果你对spring的源代码比较熟悉的话, 可以自己定一个ApplicationContext, 去实现
如果大家需要了解里面的原理的话, 可以留言, 我们再开一个帖子来解释一下
 关注公众号
关注公众号
					低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 
							
								
								    上一篇
								      推荐 9 个样式化组件的 React UI 库简评:喜欢 CSS in JS 吗?本文将介绍一些使用样式组件所构建的 React UI 库,相信你会很感兴趣的。 在 React 社区,对 UI 组件进行样式化的讨论逐步从 CSS 模块到内联 CSS 再到 CSS in JS,非常热烈。 CSS in JS 的相对崛起,能更多地受到一些开发人员的青睐,与 React 组件生态系统的兴起以及 Max Stoiber 和 200 多个贡献者的样式化组件项目的兴起紧密相关。 为了节省大家的时间,我收集了一些有用的库,它们利用样式组件提供一个简洁的开箱即用的工具包。可以帮助大家将样式化组件放到自己的应用 UI 中进行测试。 你可以使用 Bit 在可视目录中组织样式化组件集合,共享 CSS 组件,并在不同的项目中进行开发,每个组件也都可以使用 NPM 安装。 1. Rebass rebass 是一个“用样式系统构建的 React 原始 UI 组件”,在 github 上有接近 5k star。它的特点是轻量,设计精美,有 8 个可扩展、可复用的组件,这些组件还具备响应性和可定制性。 2. Zendesk 的 Garden React 组件 虽... 
- 
							
								
								    下一篇
								      Vue + ElementUI 如何优雅的上传文件到七牛OSS** 本文的上传模式是前端直传七牛oss模式,后端只负责提供token,避免泄露accessKey ** 原文:原文地址,里面有效果图 1.开通七牛OSS,创建bucket,并且实名认证,详细步骤自己看官网。传送门 2.引入七牛Java SDK <dependency> <groupId>com.qiniu</groupId> <artifactId>qiniu-java-sdk</artifactId> <version>[7.2.0, 7.2.99]</version> </dependency> 3.引入七牛Java SDK ,提供前端获取token API public void getToken(){ String host = PropKit.get("qiniuHost"); String accessKey = PropKit.get("qiniuAccessKey"); String secretKey = PropKit.get("qiniuSecretKey"); St... 
相关文章
文章评论
共有0条评论来说两句吧...

 
			 
				 
				 
				 
				 
				 
				 
				



 微信收款码
微信收款码 支付宝收款码
支付宝收款码