您的位置:首页 > 编程语言 > Java开发

使用网上流传的一个数据库连接池在Proxy.newProxyInstance处引起 java.lang.ClassCastException 问题的解决方法

2013-02-19 13:06 786 查看
getFreeConnection方法的代码如下:

public Connection getFreeConnection() {

//返回数据库连接conn的接管类,以便截住close方法

Connection conn2 = null;

if (conn instanceof Connection) {

conn2 = (Connection) Proxy.newProxyInstance(conn.getClass().getClassLoader(), conn.getClass().getInterfaces(), this);

}

return conn2;

}

用MySQLv5版本的数据库驱动没有问题,使用MySQLv6和Oracle的数据库驱动时候报如下错误:

java.lang.ClassCastException: $Proxy0 cannot be cast to java.sql.Connection

at dbpoolImpl._Connection.getFreeConnection(_Connection.java:126)

at dbpoolImpl.ConnectionFactory.getFreeConnection(ConnectionFactory.java:113)

at dbpoolImpl.DataBase_Task.checkDataBase(DataBase_Task.java:83)

at dbpoolImpl.DataBase_Task.ProcessHandle(DataBase_Task.java:227)

在网上搜索很久,终于找到解决方法,将创建代理类的语句改一下“

conn2 = (Connection) Proxy.newProxyInstance(conn.getClass().getClassLoader(), new Class[]{Connection.class}, this);

原因就在于conn.getClass().getInterfaces()方法出来的是Class类数组,此数组的第一个元素必须是Connection才能把创建的代理类转为Connection对象,大家可以使用下面的语句

Class[] interfaces = conn.getClass().getInterfaces();
for (Class c : interfaces) {
System.out.println(c.getCanonicalName());
}
打印一下使用不同数据库驱动时conn.getClass().getInterfaces()里面都有啥元素

扎客小站:www.ezhake.com
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐