使用网上流传的一个数据库连接池在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
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
相关文章推荐
- 使用网上流传的一个数据库连接池在Proxy.newProxyInstance处引起 java.lang.ClassCastException 问题的解决方法
- 使用网上流传的一个数据库连接池在Proxy.newProxyInstance处引起 java.lang.ClassCastException 问题的解决方法
- 使用网上流传的一个数据库连接池在Proxy.newProxyInstance处引起 java.lang.ClassCastException 问题的解决方法
- 使用网上流传的一个数据库连接池在Proxy.newProxyInstance处引起 java.lang.ClassCastException 问题的解决方法
- Proxy.newProxyInstance处引起 java.lang.ClassCastException 问题的解决方法
- 解决spring使用动态代理类型转换失败的问题--java.lang.ClassCastException: com.sun.proxy.$Proxy$ cannot be cast to ...
- 解决spring使用动态代理类型转换失败的问题--java.lang.ClassCastException: com.sun.proxy.$Proxy$ cannot be cast to ...
- 解决spring使用动态代理类型转换失败的问题--java.lang.ClassCastException: com.sun.proxy.$Proxy$ cannot be cast to ...今天
- java.lang.ClassCastException: com.sun.proxy.$Proxy* cannot be cast to***问题解决方案
- 解决问题:java.lang.ClassCastException: android.app.Application
- setLayoutParams 开发问题及解决 java.lang.ClassCastException:android.widget.LinearLayout$LayoutParams
- Hadoop中java.lang.ClassCastException: partition解决方法
- 解决问题java.lang.ClassCastException: android.app.Application
- 【问题解决:连接异常】 java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long
- 关于使用动态代理创建代理对象是报错 java.lang.ClassCastException: $Proxy0 cannot be cast to 的解决办法
- 开发问题及解决 java.lang.ClassCastException:android.widget.LinearLayout$LayoutParams
- java.lang.ClassNotFoundException: org.apache.jsp.WEB_002dINF.classes.views.index_jsp 问题解决方法
- 开发问题及解决 java.lang.ClassCastException:android.widget.LinearLayout$LayoutParams
- 举例说明Android开发中遇到的 java.lang.ClassCastException: java.lang.String这个问题的原因及其解决办法
- 开发问题及解决 java.lang.ClassCastException:android.widget.LinearLayout$LayoutParams