`
xw11235
  • 浏览: 15543 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

struts+hibernate+spring做图片上传

阅读更多

hibernate映射文件:

xml 代码
  1. <class name="com.yourcompany.vo.Fileload" table="FILELOAD" schema="TEST">  
  2.         <id name="id" type="integer">  
  3.             <column name="ID" precision="22" scale="0" />  
  4.             <generator class="increment" />  
  5.         </id>  
  6.         <property name="fileload" type="org.springframework.orm.hibernate3.support.BlobByteArrayType">  
  7.             <column name="FILELOAD" />  
  8.         </property>  
  9.         <property name="filename" type="string">  
  10.             <column name="FILENAME" length="50" />  
  11.         </property>  
  12.     </class>  
spring配置文件
xml 代码
  1.   <bean id="nativeJdbcExtractor" class="org.springframework.jdbc.support.nativejdbc.SimpleNativeJdbcExtractor" lazy-init="true">  
  2.    bean>  
  3. <bean id="lobHandler" class="org.springframework.jdbc.support.lob.OracleLobHandler" lazy-init="true">  
  4.   <property name="nativeJdbcExtractor">  
  5.    <ref local="nativeJdbcExtractor" />  
  6.   property>  
  7. bean>  

将lobHandle注入到sessionFactory中

xml 代码
  1. <bean id="mysessionFactory"  
  2.         class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
  3.         <property name="dataSource">  
  4.             <ref bean="dataSource" />  
  5.         property>  
  6.         <property name="lobHandler">  
  7.          <ref local="lobHandler"/>  
  8.         property>    
  9.           

在使用struts+spring+hibernate的开发中,有些时候用户会有数据库存储文件的需求,在数据库中一般会采用
Blob字段或Clob字段来存储二进制图片、流媒体或文件。现就将在实际开发中遇到的问题及解决方法告之。

一、问题需求:

 1.在持久化类中字段该用什么类型?
 2.在Struts中文件对应的数据类型是什么?
 3.在Hibernate中字段对应的类型是什么?
 4.如何在Spring中处理这些文件?

二、解决方法:

 1.在数据库中这些文件最终是以字节的形式存储二进制对象,所以在持久化类中将相应的属性定义为byte[]类型。

 2.在Struts中可以使用<html:file property="" />标签来上传文件,所以与之对应的ActionForm的属性类型为:
FormFile(org.apache.struts.upload.FormFile)类型,即使是使用了动态Form同理也是使用该类型.
提示:同时要将form标签修改为<html:form action="/Action.do" method="post" enctype="multipart/form-data">
以支持文件上传后取得上传数据。在给持久对象赋值时只需调用(FormFile) form.get("property")).getFileData();
方法即可返回byte[]。

 3.在Hibernate中文件列对应的类型可以是org.springframework.orm.hibernate3.support.BlobByteArrayType,
org.springframework.orm.hibernate3.support.ClobStringType、clob、blob、binary。什么时候用BlobBYteArrayType
什么时候用ClobStringType?一般如果要处理的对象是数据库字段类型是blob时(主要是图片,二进制对象等),
映射文件设置为:org.springframework.orm.hibernate3.support.BlobByteArrayType 数据库字段是clob(大文本对象)
类型时,要将java的属性的类型定为String,映射文件设置为: org.springframework.orm.hibernate3.support.ClobStringType。

 4.如果在spring上要使用Struts中自带的上传功能必须在spring的配置文件中加以声明.否者将会出现?
簀ava.lang.IllegalStateException: No LobHandler found for configuration - lobHandler property
must be set on LocalSessionFactoryBean异常。配置如下:

 (1).声明一个处理句柄:
  <bean id="lobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler" lazy-init="true" />
 (2).在sessionFactory中注入lobHandler:
  <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
          <property name="lobHandler" ref="lobHandler"/>
  </bean>

 提示: 指定lobHandler时,对于MySQL、DB2、MS SQL Server、Oracle 10g,使用DefaultLobHandler即可,而Oracle 9i,
则可以使用OracleLobHandler。因为Oracle9i处理lob的方式和不太一样,所以这里要用spring提供的SimpleNativeJdbcExtractor.处理Oracle9i lob类型的特殊声明:

<bean id="nativeJdbcExtractor" lazy-init="true"  class="org.springframework.jdbc.support.nativejdbc.
SimpleNativeJdbcExtractor"/>

<bean id="lobHandler" lazy-init="true"   class="org.springframework.jdbc.support.lob.OracleLobHandler">
        <property name="nativeJdbcExtractor">
            <ref bean="nativeJdbcExtractor"/>
        </property>
</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
  
 <!-- 为处理Blob类型字段的句柄声明 -->
 <property name="lobHandler">
  <ref local="lobHandler" />
 </property>
</bean>

同时还应该使用对应的JDBC驱动。

Clob字段定义:<property name="属性名" column="列名" type="org.springframework.orm.hibernate.support.ClobStringType"
 length="1048"/>这里的length是指字节,最大可以到2G.该字段在java对象中声明为String类型。

     如果使用的是mysql数据库其默认的上传文件大小只有1047552字节:如果上传的文件大于1047552字节则会出现异常
org.springframework.jdbc.UncategorizedSQLException: You can change this value on the server by setting
the max_allowed_packet' variable.根据提示可以修改mysql数据库的max_allowed_packet属性大小。
打开my.ini文件中找到# SERVER SECTION后在port=3306下面加上max_allowed_packet=?M 修改完后重启mysql服务即可成功上传。

 

显示图片

public ModelAndView showImage(HttpServletRequest request, HttpServletResponse response) throws Exception {<o:p></o:p>

       String dsbh = (String) request.getParameter("dsbh");<o:p></o:p>

       Integer idsbh = new Integer(dsbh);<o:p></o:p>

       TDs tds = tdsdao.get(idsbh);<o:p></o:p>

       //显示照片。<o:p></o:p>

       streamImage(tds.getZp(), response.getOutputStream());<o:p></o:p>

       return null;<o:p></o:p>

    }<o:p></o:p>

public void streamImage(final byte[] blob, final OutputStream contentStream) throws Exception {<o:p></o:p>

<o:p> </o:p>

       ByteArrayInputStream is = new java.io.ByteArrayInputStream(blob);<o:p></o:p>

       if (is != null) {<o:p></o:p>

           FileCopyUtils.copy(is, contentStream);<o:p></o:p>

                  }<o:p></o:p>

           }<o:p></o:p>

JSP叶面要显示照片的地方,我们像如下定义

xml 代码
  1. <image src="/file.do?method=show&id=5"/>  

 

这样照片显示就完成了,至此,我想Spring+hibernate已经展示了它在以前我们烦人的问题上展现了它独特的魅力。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics