Java 无法加载JDBC驱动程序类[com.mysql.JDBC.driver]
这是我的项目结构: 在Java 无法加载JDBC驱动程序类[com.mysql.JDBC.driver],java,mysql,spring,spring-mvc,jdbc,Java,Mysql,Spring,Spring Mvc,Jdbc,这是我的项目结构: 在cats应用程序中我有一个CatsDAO类,我试图@Autowire数据源对象: import javax.sql.DataSource; @Repository public class CatsDAO { @Autowired private DataSource dataSource; public Cat getCat(String name) { String sql = "SELECT * FROM cats WH
cats应用程序中
我有一个CatsDAO类,我试图@Autowire
数据源
对象:
import javax.sql.DataSource;
@Repository
public class CatsDAO {
@Autowired
private DataSource dataSource;
public Cat getCat(String name) {
String sql = "SELECT * FROM cats WHERE name = ?";
Connection conn = null;
try {
...
} catch (SQLException e) {
throw new RuntimeException(e);
} finally {
...
}
}
}
这是我的catswebapp
中的applicationContext.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<context:component-scan base-package="ninja.majewski"/>
<context:annotation-config/>
<mvc:annotation-driven/>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
</bean>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/cats"/>
<property name="username" value="root"/>
<property name="password" value=""/>
</bean>
</beans>
和我的cats webapp
pom.xml
文件:
<?xml version="1.0" encoding="UTF-8"?>
<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">
<parent>
<artifactId>cats</artifactId>
<groupId>ninja.majewski</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>cats-application</artifactId>
<dependencies>
<dependency>
<groupId>ninja.majewski</groupId>
<artifactId>cats-domain</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>6.0.2</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.5.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
<?xml version="1.0" encoding="UTF-8"?>
<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>groupId</groupId>
<artifactId>cats-webapp</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>ninja.majewski</groupId>
<artifactId>cats-application</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>5.2.4.Final</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.5.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
我缺少什么?您可能跳过了一些依赖项:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
mysql
mysql连接器java
5.1.6
我也有同样的问题。我在IntelliJ编辑器中遵循了这些步骤
台阶
从视频复制。检查pom.xml或lib目录中的mysql-connector-java.jar 您可以在pom.xm中附加以下代码段
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
mysql
mysql连接器java
5.1.6
您需要添加mysql连接器javajar文件
将其添加到构建路径或pom.xml中
希望对您有所帮助:)在将JDBC SQL connector的版本从5.1.6降级到5.1.31后,解决了这个问题。在我的例子中,
application.properties
中“com.mysql.JDBC.Driver之后是额外的空白字符
使用数据源的
.xml
定义(如OP示例中所示)为这种情况增加了更多的可见性。您使用哪台服务器?尝试检查您的WEB-INF/lib/是否有mysql连接器java jar,如答案所示,尝试转到最后一个连接器5.x依赖项。6.x是非常新的,我想它在与spring集成时可能会产生一些问题。@未知的Tomcat 7.0.56。没有WEB-INF/li,但有一个lib
文件夹直接在我的模块中。而且里面没有mysql-…jar…@XtremeBiker没有帮助:/6.0版本的时候我有这个依赖项。我把它改成了5.1.38,但仍然不起作用。你是我的英雄。
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>