Jack_Leonardo的博客

如果你无法简洁的表达你的想法,那只说明你还不够了解它。

java.lang.ClassCastException: com.sun.proxy.$Proxy0 cannot be cast to java.sql.Connection异常问题解决

代码如下:
		Connection proxy = (Connection) Proxy.newProxyInstance(Connection.class.getClassLoader(),
				Connection.class.getInterfaces(), new InvocationHandler() {

					@Override
					public Object invoke(Object proxy, Method method,
							Object[] args) throws Throwable {
						if ("close".equals(method.getName())) {
							returnConn(conn);
							return null;
						} else {
							return method.invoke(conn, args);
						}
					}
				});

在使用动态代理增强Connection连接对象的close方法时,我碰到了如题所示的异常。通过搜索我发现这个异常出现的原因在于我使用的mysql数据库驱动的问题,由于数据库驱动不同,Connection.class.getInterfaces()返回的结果也不同,它返回的是一个Class[]数组,然而此数组的第一个元素必须是Connection才能把创建的代理类转为Connection对象,否则就会报错。

所以这里我们可以采取一个替代方式替换Connection.class.getInterfaces(),即new Class[] { Connection.class },这样无论数据库驱动是什么版本的驱动,都能保证这个类型转换不出错。

阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Jack_Leonardo/article/details/49909257
文章标签: 异常 java
个人分类: Java
上一篇windows 10下让jar文件双击可以运行的解决方法
下一篇Composer安装出错——Unable to connect to getcomposer.org
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭