springBoot在启动过程中出现此错误。
[2020-08-13 10:28:05,461] ERROR org.springframework.boot.SpringApplication - Application startup failed
java.lang.AbstractMethodError: org.hibernate.validator.engine.ValidatorFactoryImpl.close()V
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.util.ReflectionUtils.invokeMethod(ReflectionUtils.java:216)
at org.springframework.util.ReflectionUtils.invokeMethod(ReflectionUtils.java:201)
at org.springframework.validation.beanvalidation.LocalValidatorFactoryBean.close(LocalValidatorFactoryBean.java:433)
at org.springframework.validation.beanvalidation.LocalValidatorFactoryBean.destroy(LocalValidatorFactoryBean.java:439)
at org.springframework.boot.context.properties.ConfigurationPropertiesBindingPostProcessor.freeLocalValidator(ConfigurationPropertiesBindingPostProcessor.java:233)
at org.springframework.boot.context.properties.ConfigurationPropertiesBindingPostProcessor.onApplicationEvent(ConfigurationPropertiesBindingPostProcessor.java:220)
at org.springframework.boot.context.properties.ConfigurationPropertiesBindingPostProcessor.onApplicationEvent(ConfigurationPropertiesBindingPostProcessor.java:77)
at org.springframework.context.event.SimpleApplicationEventMulticaster.doInvokeListener(SimpleApplicationEventMulticaster.java:172)
首先百度了一下,看看有没有类似的问题
https://cloud.tencent.com/developer/article/1600549
这片文章说是ValidatorFactoryImpl没有close方法导致的,那我们看看在哪里需要使用到这个方法,看下堆栈信息中,有invoke信息,通过反射调用此方法,那么方法最终调用方应该是在org.springframework.validation.beanvalidation.LocalValidatorFactoryBean.close(LocalValidatorFactoryBean.java:433)
这里就是通过反射调用close方法,然而我们现在的hibernate-validator是没有这个方法的。
那我就想到了是否要升级hibernate的版本,于是升级到了5.3.6.Final,然后顺带把
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>2.0.1.Final</version>
</dependency>
就可以了。
一开始以为是jar包冲突,但是查看依赖后,发现都是相同的版本,于是排除这个点。