一个在Tomcat下发生但不在resin下发生的java.lang.ClassCastException错误

发生错误的类是oracle.sql.BLOB,同样一段代码部署在resin中运行良好,部署到tomcat里就出错了。[@more@]

代码应该是没错的啦:

Connection conn = null;
String sql = null;
try{
sql = "SELECT rpt_template FROM RMS_REPORT_DEFINE " +
"WHERE report_id='"+reportId+"' FOR UPDATE";

conn = DBTools.getConnection();
conn.setAutoCommit(false);
Statement stmt = conn.createStatement();
ResultSet rst = stmt.executeQuery(sql);
if(rst.next()){
Blob blob = rst.getBlob(1);
oracle.sql.BLOB bstr = (oracle.sql.BLOB)blob;
BufferedOutputStream out = new BufferedOutputStream(bstr.getBinaryOutputStream());
ByteArrayInputStream in = new ByteArrayInputStream(stream.toByteArray());
int c;
while ((c=in.read())!=-1) {
out.write(c);
}
in.close();
out.close();

sql = "UPDATE RMS_REPORT_DEFINE SET template_name='"+fileName
+"',modi_user_id='" + user
+ "',modi_date=SYSDATE WHERE report_id='"+reportId+"'";
Statement st = conn.createStatement();
st.executeUpdate(sql);

conn.commit();
}
}catch(UserException ue){
try{
conn.rollback();
}catch(Exception e){
e.printStackTrace();
}
throw ue;

}catch(Exception ex){
try{
conn.rollback();
}catch(Exception e){
e.printStackTrace();
}
ex.printStackTrace();
throw new UserException(new ExpMessage());
}finally{
try{
if(conn!=null){
conn.setAutoCommit(true);
conn.close();
}
}catch(Exception e){
e.printStackTrace();
}
}

可供参考以下如何写入Oracle的BLOB字段。

找了大半天原因才发现,因为tomcat部署的原因会引起oracle.sql.BLOB bstr = (oracle.sql.BLOB)blob;这行报ClassCastException异常。我在%tomcat_home%/common/lib下和%web包%/WEB-INF/lib下都放置了oraclejdbc.jar的程序包,出现这样的异常错误,我只要将/WEB-INF/lib底下的oraclejdbc.jar删除则没问题了。不知道为什么这样?

同样的情况在resin下倒是没问题。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/67736/viewspace-799719/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/67736/viewspace-799719/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值