我希望对我在Spring中涉及属性文件的问题提供一些帮助。所以我的设置是这样的:
opto-mapping.properties - 它位于我的src文件夹中,包含我优化资源的翻译,如下所示:
generic-min.css=4037119659.css
每次运行构建“优化”时,都会更新此属性文件。然后我用
<fmt:setBundle basename="opto-mapping" />
在我想要的jsp中导入我的属性文件。然后使用以下内容引用内容:
<fmt:message key='generic-min.css' />
除了属性文件需要重新加载tomcat重启之外,这一切都很好用。我不希望每次更新资源时都要开始关闭网站。我希望属性文件能够经常自动重新加载。
我确实尝试更新spring-context.xml中的现有bean来重新加载这个属性文件,就像我对翻译一样,但是这没有用 - 很可能是因为opto-mapping.properties文件位置 - 但是你看到它需要在该位置使用fmt:setBundle加载。
<bean id="messageSource"
class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
<property name="cacheSeconds">
<value>1</value>
</property>
<property name="basenames">
<list>
<value>WEB-INF/translations/translations</value>
<value>WEB-INF/classes/opto-mapping</value>
</list>
</property>
</bean>
在这个困难时期,任何帮助或正确方向的观点都会受到高度赞赏。
我希望所有这些都能提前做好准备并提前多多谢谢!
-G。
答案 0 :(得分:5)
感谢您的回复。我现在有了这个工作,并认为我会分享财富。
所以,我将我的属性文件从src文件夹移到了WEB-INF / properties。
我更新了以下bean来加载属性文件:
<bean id="messageSource"
class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
<property name="cacheSeconds">
<value>1</value>
</property>
<property name="basenames">
<list>
<value>WEB-INF/translations/translations</value>
<value>WEB-INF/properties/opto-mapping</value>
</list>
</property>
</bean>
现在,我之前使用setBundle加载到我的属性文件中,如下所示:
<fmt:setBundle basename="opto-mapping" />
但是我发现显然我的属性文件不再被加载,因为我已经移动了它。但是由于我的bean设置,正在加载新的属性文件,但是我的setBundle正在覆盖它。
所以,解决方法是删除setBundle,现在我的属性文件正在重新加载!
再次感谢!
答案 1 :(得分:4)
Tomcat不会重新加载类路径上的资源。这在[{1}} ReloadableResourceBundleMessageSource
中说明了
由于应用程序服务器通常会缓存从类路径加载的所有文件,因此有必要将资源存储在其他位置(例如,在Web应用程序的“WEB-INF”目录中)。否则,类路径中文件的更改将不会反映在应用程序中。
此类路径位置包括WEB-INF/classes
,并且不会被释放。
尝试在其他位置移动opto-mapping.properties
(例如WEB-INF/messages
),然后尝试。
答案 2 :(得分:1)
你可能会尝试一些事情。
<fmt:setBundle>
最终将调用ResourceBundle.getBundle(String, Locale, ClassLoader)
,其中字符串将是您的基本名称,类加载器将为Thread.currentThread().getContextClassLoader()
。如果您使用的是JDK 1.6,则可以尝试使用ResourceBundle.clearCache(ClassLoader)
清除捆绑缓存。在servlet过滤器中执行此操作并将其与其他逻辑组合以确定何时应清除缓存是有意义的。
另一个角度是更直接地控制属性文件的加载和JSTL的配置。再次,使用过滤器(忽略异常处理):
ClassLoader ctxLoader = Thread.currentThread().getContextClassLoader();
URL propsURL = ctxLoader.getResource("opto-mapping.properties");
URLConnection propsConn = propsURL.openConnection();
long propsLastModified = propsConn.getLastModified();
// decide if you want to reload...
propsConn.setUseCaches(false);
InputStream propsIn = propsConn.getInputStream();
ResourceBundle propsBundle = new PropertyResourceBundle(propsIn);
propsIn.close();
LocalizationContext propsCtx = new LocalizationContext(propsBundle);
ServletContext servletCtx = this.filterConfig.getServletContext();
Config.set(servletCtx, Config.FMT_LOCALIZATION_CONTEXT, propsCtx);
然后您可以在页面中使用<fmt:message>
。您可以在JSTL API中找到LocalizationContext
和Config
的文档。
可能有很多其他变体,但请务必查看JDK 1.6中较新的ResourceBundle
(包括ResourceBundle.Control
)新增内容,请记住“低级”API的功能与URLConnection
一样,熟悉通过其API提供的JSTL的更多编程方面。