maven pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>Test</groupId>
<artifactId>Test</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>Test</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.18</version>
</dependency>
</dependencies>
在代码中我试图执行Class.forName("com.mysql.jdbc.Driver")
。
我明白了:
java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
但我检查过jboss-as-7.0.2.Final\standalone\deployments\Test.war\WEB-INF\lib
中有mysql.jar,它有com.mysql.jdbc.Driver类。
答案 0 :(得分:4)
通常,您不应该在war文件中包含JDBC驱动程序。
我建议您将驱动程序标记为已提供,并将其添加到服务器的lib目录中。
PS。我不确定你为什么要使用
Class.forName("com.mysql.jdbc.Driver")
你的代码中的。为什么不让包含管理您的连接和交易?
答案 1 :(得分:1)
发生此错误是因为您的mysql jar不在您的运行时类路径中。如果您使用的是maven,
答案 2 :(得分:0)
您似乎正在使用JBoss AS7。查看此处的说明:https://community.jboss.org/wiki/DataSourceConfigurationInAS7
基本上,你应该
Class.forName()是容器未提供数据源时常用的习惯用法。在现代Java EE服务器中,它们是提供的。
答案 3 :(得分:0)
我的用例略有不同。我在一个独立的应用程序中使用apache的BasicDataSource。
我遇到了这个异常,因为我用setDriverClassName
而不是com.mysql.jdbc.Driver.class.toString()
作为字符串调用"com.mysql.jdbc.Drive"
(所以编译时检查确保没有拼写错误或者Driver的位置没有改变在版本升级......等等。)
但是!
当您查看Driver的实现时,它有一个静态初始化块:
static {
try {
java.sql.DriverManager.registerDriver(new Driver());
} catch (SQLException E) {
throw new RuntimeException("Can't register driver!");
}
}
当我写com.mysql.jdbc.Driver.class.toString()
时,这个初始化块执行得太早,导致后来误导ClassNotFoundException
。切换到"com.mysql.jdbc.Driver"
后,我的应用程序开始工作。
这是静态变为邪恶的情况:)