java.lang.NocalssDefFoundError:oracle.jdbc.driver.T4CpreparedStatement

原来吧项目发布到weblogic9中没问题。。。现在发布到weblogic10.3偶尔发现这个问题、、

现象:

应用连接数据库是通过jdbc连接池来连接的,在jdk版本为1.5的weblogic10.1版本上部署应用,应用正常跑起来,没有异常;但在jdk版本为1.6的weblogic10.3版本上部署应用时,应用启动时报异常:java.lang.VerifyError: (class: oracle/jdbc/pool/OracleConnectionCacheImpl, method: getPooledConnection signature: (Ljava/lang/String;Ljava/lang/String;)Ljavax/sql/PooledConnection;) Bad access to protected data。
问题分析:
oracle/jdbc/pool/OracleConnectionCacheImpl是oracle提供的jdbc驱动中的类,首先想到这个问题基本上是与jdbc驱动程序有关,是不是jdbc驱动程序的版本与数据库版本不匹配?有时候jdbc驱动程序版本与数据库版本不一致会导致一些莫名其妙的异常。上google查原因,查到这个异常是由于weblogic10.3本身自带的lib库中有一个ojdbc6.jar的类包,在weblogic.jar包的MANIFEST.MF中就已经将ojdbc6.jar包加入到classpath了,在类路径上ojdbc6.jar包在前而应用lib中提供的jdbc驱动包在后,在查找类时先找到了ojdbc6.jar包里的类导致这个异常的发生,具体为什么会导致这个异常发生,我也不知道,希望知道的朋友们不吝赐教。
问题解决:
将weblogic本身自带的lib库(server/lib目录)中的ojdbc6.jar删除掉。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值