java.lang.AbstractMethodError: com.mysql.jdbc.Connection.isValid(I)Z

java.lang.AbstractMethodError: com.mysql.jdbc.Connection.isValid(I)Z

我正在尝试使用数据源将我的 Servlet 连接到 mysql 数据库。但是每当我 运行 我的 servlet 时,我都会得到这个异常:

java.lang.AbstractMethodError: com.mysql.jdbc.Connection.isValid(I)Z
    org.apache.tomcat.dbcp.dbcp2.DelegatingConnection.isValid(DelegatingConnection.java:913)
    org.apache.tomcat.dbcp.dbcp2.PoolableConnection.validate(PoolableConnection.java:282)
    org.apache.tomcat.dbcp.dbcp2.PoolableConnectionFactory.validateConnection(PoolableConnectionFactory.java:356)
    org.apache.tomcat.dbcp.dbcp2.BasicDataSource.validateConnectionFactory(BasicDataSource.java:2306)
    org.apache.tomcat.dbcp.dbcp2.BasicDataSource.createPoolableConnectionFactory(BasicDataSource.java:2289)
    org.apache.tomcat.dbcp.dbcp2.BasicDataSource.createDataSource(BasicDataSource.java:2038)
    org.apache.tomcat.dbcp.dbcp2.BasicDataSource.getConnection(BasicDataSource.java:1532)
    Servlet.AbdulTayyebs.processRequest(AbdulTayyebs.java:36)
    Servlet.AbdulTayyebs.doGet(AbdulTayyebs.java:57)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:622)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)

这是我的 Content.xml

<Resource name="jdbc/abdultayyebs" auth="Container"
          type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver"
          url="jdbc:mysql://127.0.0.1:4000/abdultayyebs?zeroDateTimeBehavior=convertToNull"
          username="root" password="february1996" maxActive="5" maxIdle="2"
          maxWait="1000"/>

这是我的 web.xml

  <resource-ref>
  <description>DB Connection</description>
  <res-ref-name>jdbc/abdultayyebs</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
  <res-auth>Container</res-auth></resource-ref>

这是我的 servlet AbdulTayyebs

 import java.io.IOException;
 import java.io.PrintWriter; 
 import java.sql.Connection;
 import java.sql.SQLException;
 import javax.naming.Context;
 import javax.naming.InitialContext;
 import javax.servlet.ServletConfig;
 import javax.servlet.ServletException;
 import javax.servlet.http.HttpServlet;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 import javax.sql.DataSource;

 public class AbdulTayyebs extends HttpServlet {

  DataSource ds=null;  

 @Override
 public void init(ServletConfig config)throws ServletException{
    try {
     Context initContext = new InitialContext();
     Context envContext  = (Context)initContext.lookup("java:/comp/env");
     ds = (DataSource)envContext.lookup("jdbc/abdultayyebs");  
    } catch (Exception e) {
     throw new ServletException("Something went wrong while Initializing the Servlet",e);
    }
  }

    protected void processRequest(HttpServletRequest request,                   
       HttpServletResponse response)
       throws ServletException,IOException {
       PrintWriter write = response.getWriter();
       try {   
       Others.Action a = Others.ActionFactory.CreateAction(request);
     try(Connection c=ds.getConnection()){
     String page = a.Execute(c,request,request.getSession(false));
       request.getRequestDispatcher(page).forward(request, response); 
      }      
   }     
   catch (SQLException e) {
     write.println(e);
   }
   catch (ServletException e) {
     write.println(e);     
   }
   catch (Exception e) {       
    write.println(e);
   }   
 }

 @Override
 protected void doGet(HttpServletRequest request, HttpServletResponse  response)
        throws ServletException, IOException {
      processRequest(request, response);
   }

@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
     processRequest(request, response);
     } 
   }

我还在 tomcat 的 lib 文件夹中添加了 mysql jdbc 驱动程序,但即使这样也没有帮助?如果有人能帮助我,我将不胜感激

java.lang.AbstractMethodError: com.mysql.jdbc.Connection.isValid(I)Z

这意味着 MySQL JDBC 驱动程序已过时,因此它不支持 Java 1.6 的 Connection#isValid() 方法。

Upgrade it。并确保在运行时类路径中只有一个 MySQL JDBC 驱动程序 JAR 文件。

另请参阅:

  • Connect Java to a MySQL database

对我来说,解决方案不是升级我的驱动程序 (JT400)。即使是最新版本 (9.1) 似乎也没有实现 isValid() (它在代码中被注释掉了?)。

对我有用的是为我的数据库连接池提供一个 validationQuery。例如:

validationQuery=SELECT current date FROM sysibm.sysdummy1

就我而言,我将 ojdbc 从版本 14 升级到版本 6。我有工件 ojdbc14,然后我将它更改为 ojdbc6。我在这里迷路了一段时间,因为我认为 14 是 14>6 的更新版本。但 14 表示 java 1.4。 6 表示 java6

net.sourceforge.jtds.jdbc.JtdsConnection 没有实现 isValid()

因此您需要指定连接测试查询以确保 isValid() 方法未被调用 将以下行添加到 application.properties 文件为我解决了错误。

spring.datasource.hikari.connection-test-query=SELECT 1

这是我读到的关于 isValid 方法的内容 (source)。 驱动程序(此处 MySQL)会尝试检查您的连接是否有效。 不确定它是如何工作的(因为即使我的 MySQL instance/service 启动并且 运行 也不允许连接)。 因此,在 spring application.properties 文件

中使用以下字符串

spring.datasource.hikari.connection-test-query=select 1 来自双重 (或任何测试查询,- select 来自 dual 的 sysdate)

对我来说,我在数据库连接池配置中添加了 validationQuery 参数。

<Resource name="jdbc/abdultayyebs" auth="Container"
      type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver"
      url="jdbc:mysql://127.0.0.1:4000/abdultayyebs?zeroDateTimeBehavior=convertToNull"
      username="root" password="february1996" maxActive="5" maxIdle="2"
      maxWait="1000" validationQuery="SELECT 1"/>

我使用 DB2 的 jt400 得到了同样的结果,这对我有用 validationQuery="SELECT 1 来自 SYSIBM.SYSDUMMY1"