java.lang.NoClassDefFoundError: Could not initialize class cn.xxx.smis.util.druidUtil
在JavaWeb开发中,使用Intellij IDEA正确配置好Tomcat服务器,并成功启动之后(见下图)
1. 在使用druid连接池创建Connection时,出现如下错误:
javax.servlet.ServletException: Servlet执行抛出一个异常
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
根本原因。
java.lang.NoClassDefFoundError: Could not initialize class cn.xxx.smis.util.druidUtil
解决办法
将druid-xxx.jar
拷贝到WEB-INF
下的lib
文件夹
注意: 需要将该lib添加到当前项目模块的依赖中,如下图
Project Structure–>Modules–>Dependencies–>点击右侧的 + 号,选择WEB-INF下的lib路径,并将其scope设置为Provided,最后点击Apply
重新启动服务器,如果仍然出现上述情况,那么需要先清除项目的缓存,clean一下,最后再重新Build
然而,又出现了了如下错误,说明没有在web项目下没有调用执行SQL语句的包,可以将mysql-connector-java-5.1.49-bin.jar
也导入到WEB-INF下的lib路径下,重复上述的clean和Build步骤
java.lang.RuntimeException: 查询结果有错误!
....
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
最后成功运行,在控制台得到如下查询结果
补充: 出现以下错误,同样是执行clean和build操作,清除项目缓存结果
严重: ContainerBase.addChild: start:
org.apache.catalina.LifecycleException: 无法启动组件[StandardEngine[Catalina].StandardHost[localhost].StandardContext[]]
at org.apache.catalina.util.LifecycleBase.handleSubClassException(LifecycleBase.java:440)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:198)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:1007)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:983)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:639)
总结:
在配置中,如果在成功启动tomcat服务器之后,调用service方法出现异常时,一般根据报错的提示信息,导入相应的jar包到WEB-INF下的lib路径下,然后执行Clean和Build,清除项目结果缓存,最后重新启动服务器即可