spring+hibernate工程使用JNDI连接部署至websphere,报错Caused by: java.lang.ClassNotFoundException: oracle.sql.BLO

spring+hibernate工程使用JNDI连接部署至websphere,保存oracle大字段报错Caused by: java.lang.ClassNotFoundException: oracle.sql.BLO。

org.springframework.dao.InvalidDataAccessApiUsageException: Couldn't initialize OracleLobHandler because Oracle driver classes are not available. Note that OracleLobHandler requires Oracle JDBC driver 9i or higher!; nested exception is java.lang.ClassNotFoundException: oracle.sql.BLOB

原文链接地址:http://windring.iteye.com/blog/108171

参考资料:http://my.oschina.net/u/218421/blog/38576

正文引用:

在spring里 插入 BLOB字段
kp.setContent(content.getBytes()); 
方法 :hibernate saveOrUpdate


Caused by: java.lang.ClassNotFoundException: oracle.sql.BLOB。
       使用tomcat 没问题。
       可服务器改为 WebSphere .就报错。

把Spring内置提供的NativeJdbcExtractor转换器 改了一下,结果:问题解决。
———————————————————————————————————————————————————————
总结如下:
      1、对于我们的工程:
           在发布环境中,要将nativeJdbcExtractor  换成             org.springframework.jdbc.support.nativejdbc.WebSphereNativeJdbcExtractor
留意log4j日志,此时的blob字段的java类型为oracle.sql.Blob
      2、Spring内置提供的NativeJdbcExtractor转换器有:
          C3P0NativeJdbcExtractor
          CommonsDbcpNativeJdbcExtractor
          JBossNativeJdbcExtractor
          NativeJdbcExtractor
          NativeJdbcExtractorAdapter
          SimpleNativeJdbcExtractor
          WebLogicNativeJdbcExtractor
          WebSphereNativeJdbcExtractor
          XAPoolNativeJdbcExtractor
          要根据不同服务器及时修改,以免浪费大量时间。
          位于org\springframework\jdbc\support\nativejdbc下

在此总结。

当在Java Web应用程序中运行JSP时,如果出现java.lang.ClassNotFoundException: com.mysql.jdbc.Driver异常,则可能是由于缺少MySQL JDBC驱动程序引起的。解决此问题的步骤如下: 1.下载MySQL JDBC驱动程序,可以从MySQL官方网站下载或从Maven中央仓库下载。 2.将下载的JDBC驱动程序jar文件复制到Web应用程序的lib目录中。 3.在Web应用程序的classpath中添加JDBC驱动程序jar文件。可以通过以下方式之一实现: a.在Web应用程序的WEB-INF目录下创建一个lib目录,并将JDBC驱动程序jar文件复制到该目录中。这样,JDBC驱动程序jar文件将自动添加到Web应用程序的classpath中。 b.在Web应用程序的web.xml文件中添加以下代码: ```xml <web-app> <display-name>MyWebApp</display-name> <listener> <listener-class>com.example.MyServletContextListener</listener-class> </listener> <servlet> <servlet-name>MyServlet</servlet-name> <servlet-class>com.example.MyServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>MyServlet</servlet-name> <url-pattern>/myservlet</url-pattern> </servlet-mapping> <resource-ref> <description>My DataSource Reference</description> <res-ref-name>jdbc/myDataSource</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref> </web-app> ``` 其中,<resource-ref>元素用于定义一个JNDI资源引用,可以在Web应用程序中使用该引用来访问JDBC驱动程序。在这个例子中,我们定义了一个名为jdbc/myDataSource的JNDI资源引用,它的类型是javax.sql.DataSource,授权方式是Container。在Web应用程序中,我们可以通过以下方式之一来访问这个JNDI资源引用: i.使用JNDI API ii.使用注解 iii.使用XML配置文件 4.重启Web服务器,然后再次运行JSP页面,应该就不会再出现java.lang.ClassNotFoundException: com.mysql.jdbc.Driver异常了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值