1---bean的冲突
如下所示:
严重: Context initialization failed
org.springframework.beans.factory.BeanDefinitionStoreException: Unexpected exception parsing XML document from class path resource [mysqlHibernateContext.xml]; nested exception is org.springframework.context.annotation.ConflictingBeanDefinitionException: Annotation-specified bean name 'userDao' for bean class [com.tsmi.RepositoryCheck.dao.UserDao] conflicts with existing, non-compatible bean definition of same name and class [com.tsmi.mysql.dao.UserDao]
at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:413)
上面所示的报错,对应eclipse中的问题处如下:
扫描了两个不同的包package,但是里面的bean,也就是dao和service的类的名字是重复的,package不同但是bean名字一样,这样,就相当于名字重复了,进去改。
2---invalid LOC header (bad signature)
信息: At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time.
十二月 18, 2017 4:39:24 下午 org.apache.catalina.core.ContainerBase startInternal
严重: A child container failed during start
java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to initialize component [org.apache.catalina.webresources.JarResourceSet@350d9d23]
Caused by: java.lang.IllegalArgumentException: java.util.zip.ZipException: invalid LOC header (bad signature)
at org.apache.catalina.webresources.AbstractSingleArchiveResourceSet.initInternal(AbstractSingleArchiveResourceSet.java:113)
at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:136)
... 33 more
说实话这个错误,我根本看不出来有什么错。上网查看说是maven有什么依赖有问题。
我认为这个方向是对的。
最终放出大招:找到你自己maven的默认目录,整体删掉repository目录
然后
貌似管用
总结,这一次集中出现eclipse的报错,原因是之前的很多错误
你来想想eclipse上使用tomcat的时候报错,如果eclipse上不启动tomcat根本没有报错的,而且如果将eclipse上tomcat中的web项目移除,也不会报错的前提下。
加上项目就出错,说明肯定是eclipse上tomcat的web项目的配置有问题。
问题在哪里呢?
我最开始使用SpringJDBC访问access数据库
后来SpringJDBC访问mysql数据库
后来通过Spring集成Hibernate访问mysql数据库
上述三种数据访问,本身就是三种不同的ApplicationContext.xml文件的写法,一方面扫描bean包的语句,如果对照我之前博文中展示的xml代码你会发现与下面的代码不同
<context:component-scan base-package="com.tsmi.mysql.dao"/>
<context:component-scan base-package="com.tsmi.mysql.service"/>
<context:component-scan base-package="com.tsmi.mysql.web"/>
<!--之前没有扫描下面的包-->
<context:component-scan base-package="com.tsmi.RepositoryCheck.dao"/>
<context:component-scan base-package="com.tsmi.RepositoryCheck.service"/>
<context:component-scan base-package="com.tsmi.RepositoryCheck.web"/>
看上面的代码,如果你不扫描但是以后用到对应的bean,那么tomcat启动的时候很可能报错。
即使一时没有报错,如果你发布了项目war文件到了其他环境,没有缓存的情况下,绝对会报错。
3---eclipse中配置hibernate configuration报错
报错信息为Reading schema error:Could not get list of tables from database.Probably a JDBC driver problem.如下图所示
我直接说最终结果:mysql-connector的版本有问题
下图这个jar是maven导入的,版本6.0.6,版本太高了
如上图
换成5.1.44就好了