在使用 Velocity 2.0 启动我的 Web 应用程序时,出现以下错误:
Caused by: java.lang.NoClassDefFoundError:
org/apache/velocity/runtime/log/CommonsLogLogChute
at org.springframework.ui.velocity.VelocityEngineFactory.createVelocityEngine(VelocityEngineFactory.java:240)
at org.springframework.ui.velocity.VelocityEngineFactoryBean.afterPropertiesSet(VelocityEngineFactoryBean.java:60)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1687)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1624)
... 34 more
已满足所有依赖项。我们正在使用
- slf4j-api-1.7.25.jar
- slf4j-simple-1.7.25.jar
- commons-lang3-3.5.jar
- commons-io-2.5.jar
- commons-logging-1.2.jar(是的,我们有 Commons-Logging)
在 applicationContext.xml 中,velocityEngine bean 定义如下
<bean id="velocityEngine"
class="org.springframework.ui.velocity.VelocityEngineFactoryBean"/>
对此有什么想法吗?
我的文件 velocity-engine-core-2.0.jar
只包含以下 .runtime
子包:
defaults, directive, parser, resource, visitor
但没有log
。
更新 Spring Velocity Engine bean 声明中的以下 overrideLogging = FALSE 解决了该问题。 但为什么呢?
<bean id="velocityEngine" class="org.springframework.ui.velocity.VelocityEngineFactoryBean">
<property name="overrideLogging" value="false" />
</bean>
我只是听了一个提示 https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/ui/velocity/VelocityEngineFactory.html 但不确定发生了什么。
最佳答案
当 overrideLogging 为真时,类 org.apache.velocity.runtime.log.CommonsLogLogChute 仍然是 Spring 所必需的,而它在 Velocity 2.0 中已经消失,因为 Velocity 现在使用 slf4j 日志框架。
如果您需要 overrideLogging 为真,则需要等待 Spring Velocity 类的更新。
2022 年 6 月 21 日编辑 - 从 2.3 版开始,Velocity 确实提供了 Spring support .
关于java - 速度 2.0 : NoClassDefFoundError: org/apache/velocity/runtime/log/CommonsLogLogChute,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46118555/