java.lang.ClassNotFoundException:com.mysql.jdbc.Driver(maven + jboss)

时间:2011-11-23 14:22:54

标签: java mysql maven jboss jboss7.x

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类。

4 个答案:

答案 0 :(得分:4)

通常,您不应该在war文件中包含JDBC驱动程序。

我建议您将驱动程序标记为已提供,并将其添加到服务器的lib目录中。

PS。我不确定你为什么要使用

Class.forName("com.mysql.jdbc.Driver")
你的代码中的

。为什么不让包含管理您的连接和交易?

答案 1 :(得分:1)

发生此错误是因为您的mysql jar不在您的运行时类路径中。如果您使用的是maven,

  1. 打开您的EAR /网络项目属性
  2. 点击“部署大会”
  3. 点击“添加...”
  4. 选择“Java Build Path Entries”
  5. 点击“下一步”
  6. 选择“Maven Dependencies”
  7. 点击“完成”

答案 2 :(得分:0)

您似乎正在使用JBoss AS7。查看此处的说明:https://community.jboss.org/wiki/DataSourceConfigurationInAS7

基本上,你应该

  1. 安装mysql连接器
  2. 使用它创建数据源
  3. 使用JNDI配置
  4. 引用该数据源

    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"后,我的应用程序开始工作。

这是静态变为邪恶的情况:)