简体   繁体   中英

java.lang.ClassNotFoundException: com.mysql.jdbc.Driver

Im building Maven Java Web application and when I do

Class.forName("com.mysql.jdbc.Driver");

I get

java.lang.ClassNotFoundException: com.mysql.jdbc.Driver 

mysql-connector is added to my pom.xml file like this

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.32</version>
    <scope>provided</scope>
</dependency>

But I keep getting this. I even tried downloading mysql-connector and adding it manually to project, but it doesn't change anything.

I also have the same app without Maven, and same code works fine

You have set the scope of your dependency as provided . This means that the jar is used when compiling the project (although you shouldn't need it to compile it, since you should only use standard JDBC classes), but that it's not included in the jar or war created by the build, because this dependency is supposed to be "provided" by the application server where you deploy the application.

So, either you actually intend to have this jar provided, and it should be in the application server's classpath, or you want to bundle this jar with the application, and it should have the scope runtime (because you need it to run the app, but not to compile it), instead of provided .

You need to add Heroku plugin as maven dependencies to get maven dependencies added at heroku.

Deploying Standalone Applications

<build>
  <plugins>
    <plugin>
      <groupId>com.heroku.sdk</groupId>
      <artifactId>heroku-maven-plugin</artifactId>
      <version>2.0.1</version>
      <configuration>
        <appName>${heroku.appName}</appName>
        <processTypes>
          <web>java $JAVA_OPTS -cp target/classes:target/dependency/* Main</web>
        </processTypes>
      </configuration>
    </plugin>
  </plugins>
</build>

Now, if you have the Heroku Toolbelt installed, run:

$ mvn heroku:deploy

Deploying WAR Files

<build>
  <plugins>
    <plugin>
      <groupId>com.heroku.sdk</groupId>
      <artifactId>heroku-maven-plugin</artifactId>
      <configuration>
        <appName>${heroku.appName}</appName>
      </configuration>
    </plugin>
  </plugins>
</build>

Now, if you have the Heroku Toolbelt installed, run:

$ mvn heroku:deploy-war

Very simply you can fix your problem. This is not a compilation issue, it is clearly a run time issue, you must add the jar file in your system class path. If your package is in a .war or .ear format you can fix this by changing the maven configuration from <scope>provided</scope> to <scope>local</scope> . This correction will add the jar to your local lib folder/directory.

This will definitely fix your issue.

I like the answers above. I wrestled with the same problem on my Windows 10 machine using the -cp or -classpath switch with java. But in the end, since I wanted the com.mysql.jdbc.Driver available for all my runnable classes, I just created the CLASSPATH environmental variable in the machine's environmental variable list. You have to be sure and add the current directory path . to the list otherwise the JVM can't find the class [for the main function] when you issue the command "java MainClassName" at the command prompt.

I am using eclipse and adding the external jar files to a project is easy and the projects run fine in the IDE without the CLASSPATH variable defined, but they still don't run in a command prompt window without the CLASSPATH variable defined. I also found that with the UcanAccess [a solution for ODBC in JE 8 and greater] driver I had to include all 5 jar files in the CLASSPATH variable.

I haven't tried building an executable jar file yet to see if I need the CLASSPATH variable. That is my next item to check.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM