开发使用的是SpringMVC+Velocity的架构,要使用Velocity的tools,在整合时代码如下:
<bean id="viewResolver"
class="org.springframework.web.servlet.view.velocity.VelocityViewResolver">
<property name="cache" value="true" />
<property name="suffix" value=".vm" />
<property name="contentType">
<value>text/html;charset=UTF-8</value>
</property>
<property name="requestContextAttribute" value="rc" />
<property name="toolboxConfigLocation" value="velocity-toolbox.xml" />
<!-- 定义velocity DATE 格式化 -->
<property name="dateToolAttribute">
<value>dateTool</value>
</property>
</bean>
这个volocity-toolbox.xml配置文件是放在src下,也就是说在打成war包之后是放在WEB-INF/classes这个目录下,可是一直报错误如下:
Caused by: java.lang.NullPointerException
at org.springframework.web.servlet.view.velocity.VelocityToolboxView.createVelocityContext(VelocityToolboxView.java:111)
at org.springframework.web.servlet.view.velocity.VelocityView.renderMergedTemplateModel(VelocityView.java:287)
at org.springframework.web.servlet.view.AbstractTemplateView.renderMergedOutputModel(AbstractTemplateView.java:167)
at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:264)
at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1208)
at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:992)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:939)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:953)
... 23 more
网上也没有查到资料,于是调试了下源码发现在类org.apache.velocity.tools.view.servlet.ServletToolboxManager中读取这个文件使用servletContext.getResourceAsStream这个API来读取的,这样问题就清楚了,开始以为是用类加载器的方式读取的。具体servletContext.getResourceAsStream如何使用大家可以看其他资料,这里不再赘述。不过后来我回头看别人的配置文档时,的确发现他们在配置这个文件路径时使用的是项目的相对路径,于是我将这个路径改成:/WEB-INF/classes/velocity-toolbox.xml,问题解决!