DB2异常com.ibm.db2.jcc.c.DisconnectException: encoding not supported的一种解决方法

本文介绍了一种在使用Apache Tomcat部署Java Web应用程序时遇到的DB2数据库连接异常:Cannot create PoolableConnectionFactory (encoding not supported!!)。该异常发生在尝试通过BasicDataSource建立数据库连接时,并提供了详细的堆栈跟踪。解决方案包括更新db2java.jar、db2jcc.jar及db2jcc_license_cu.jar等DB2 JDBC驱动程序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果你的程序在运行的过程中抛出如下异常:

org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (encoding not supported!!)
	at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1225)
	at org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:880)
	at com.asiainfo.iaet.util.dataSource.DBConnectionFactory.getConnection(DBConnectionFactory.java:34)
	at com.asiainfo.iaet.services.DBOperator.openConnection(DBOperator.java:852)
	at com.asiainfo.iaet.services.DBOperator.select(DBOperator.java:279)
	at com.asiainfo.iaet.helpers.StaticMemData.init(StaticMemData.java:104)
	at com.asiainfo.iaet.servlet.SysInitServlet.init(SysInitServlet.java:53)
	at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1173)
	at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:993)
	at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4149)
	at org.apache.catalina.core.StandardContext.start(StandardContext.java:4458)
	at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:792)
	at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
	at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:528)
	at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:987)
	at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:909)
	at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:497)
	at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1206)
	at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:314)
	at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1056)
	at org.apache.catalina.core.StandardHost.start(StandardHost.java:722)
	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
	at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:445)
	at org.apache.catalina.core.StandardService.start(StandardService.java:516)
	at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
	at org.apache.catalina.startup.Catalina.start(Catalina.java:583)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:290)
	at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
Caused by: com.ibm.db2.jcc.c.DisconnectException: encoding not supported!!
	at com.ibm.db2.jcc.b.bb.b(bb.java:1610)
	at com.ibm.db2.jcc.b.cb.ac(cb.java:4454)
	at com.ibm.db2.jcc.b.cb.a(cb.java:4392)
	at com.ibm.db2.jcc.b.cb.c(cb.java:4314)
	at com.ibm.db2.jcc.b.cb.b(cb.java:4247)
	at com.ibm.db2.jcc.b.cb.a(cb.java:4225)
	at com.ibm.db2.jcc.b.cb.l(cb.java:373)
	at com.ibm.db2.jcc.b.cb.d(cb.java:145)
	at com.ibm.db2.jcc.b.b.Tb(b.java:1274)
	at com.ibm.db2.jcc.b.b.a(b.java:1166)
	at com.ibm.db2.jcc.b.b.q(b.java:934)
	at com.ibm.db2.jcc.b.b.a(b.java:702)
	at com.ibm.db2.jcc.b.b.<init>(b.java:305)
	at com.ibm.db2.jcc.DB2Driver.connect(DB2Driver.java:162)
	at org.apache.tomcat.dbcp.dbcp.DriverConnectionFactory.createConnection(DriverConnectionFactory.java:38)
	at org.apache.tomcat.dbcp.dbcp.PoolableConnectionFactory.makeObject(PoolableConnectionFactory.java:294)
	at org.apache.tomcat.dbcp.dbcp.BasicDataSource.validateConnectionFactory(BasicDataSource.java:1247)
	at org.apache.tomcat.dbcp.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1221)
	at org.apache.tomcat.dbcp.dbcp.BasicDataSource.getConnection(BasicDataSource.java:880)
	at com.asiainfo.iaet.util.dataSource.DBConnectionFactory.getConnection(DBConnectionFactory.java:34)
	at com.asiainfo.iaet.services.DBOperator.openConnection(DBOperator.java:852)
	at com.asiainfo.iaet.services.DBOperator.select(DBOperator.java:279)
	at com.asiainfo.iaet.helpers.StaticMemData.init(StaticMemData.java:104)
	at com.asiainfo.iaet.servlet.SysInitServlet.init(SysInitServlet.java:48)
	at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1173)
	at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:993)
	at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4149)
	at org.apache.catalina.core.StandardContext.start(StandardContext.java:4458)
	at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
	at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
	at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:526)
	at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:987)
	at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:909)
	at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:495)
	at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1206)
	at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:314)
	at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
	at org.apache.catalina.core.StandardHost.start(StandardHost.java:722)
	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
	at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
	at org.apache.catalina.core.StandardService.start(StandardService.java:516)
	at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
	at org.apache.catalina.startup.Catalina.start(Catalina.java:583)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
	... 1 more
你可以尝试着将你的所有的db2的jar包升级一下,升级的java包有

db2java.jar

db2jcc.jar

 db2jcc_license_cu.jar

如果你是web程序,这些包可能在Tomcat的lib目录下


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值