<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    飛艷小屋

    程序--人生--哲學___________________歡迎艷兒的加入

    BlogJava 首頁 新隨筆 聯系 聚合 管理
      52 Posts :: 175 Stories :: 107 Comments :: 0 Trackbacks

     hibernate當中使用hql進行查詢的時候,如果參數是中文,這hql打印為亂碼。以前從來沒有遇到過的問題,郁悶。經過無數次的嘗試之后都無法解 決,查找資料突然發現這個hibernate3的一個bug。在hibernate3當中使用antlr來解析hql,估計是這個的問題。解決方法為: 1、采用占位符,然后setString 2、將 hibernate.query.factory_class 屬性設置成 org.hibernate.hql.classic.ClassicQueryTranslatorFactory

    spring中的代碼如下<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"
             dependency-check="default"
             lazy-init="default"
             abstract="false"
         >
          <!-- 在SessionFactory類里注入DataSource -->
      <property name="dataSource" ref="dataSource" />
      <property name="hibernateProperties">
       <props>
        <!-- SQL方言-->
        <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
        <!-- 是否把SQL語句表示出來-->
        <prop key="hibernate.show_sql">true</prop>
        <prop key="hibernate.cglib.use_reflection_optimizer">true</prop>
        .......
        <prop key="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</prop>
       </props>
      </property>
    下載本文源代碼


      引言

      文件的上傳和下載在J2EE編程已經是一個非常古老的話題了,也許您馬上就能掰著指頭數出好幾個著名的大件:如SmartUpload、Apache 的FileUpload。但如果您的項目是構建在Struts+Spring+Hibernate(以下稱SSH)框架上的,這些大件就顯得笨重而滄桑了,SSH提供了一個簡捷方便的文件上傳下載的方案,我們只需要通過一些配置并輔以少量的代碼就可以完好解決這個問題了。

      本文將圍繞SSH文件上傳下載的主題,向您詳細講述如何開發基于SSH的Web程序。SSH各框架的均為當前最新版本:

      ·Struts 1.2

      ·Spring 1.2.5

      ·Hibernate 3.0

      本文選用的數據庫為Oracle 9i,當然你可以在不改動代碼的情況下,通過配置文件的調整將其移植到任何具有Blob字段類型的數據庫上,如MySQL,SQLServer等。

      總體實現

      上傳文件保存到T_FILE表中,T_FILE表結構如下:


    圖 1 T_FILE表結構

      其中:

      ·FILE_ID:文件ID,32個字符,用Hibernate的uuid.hex算法生成。

      ·FILE_NAME:文件名。

      ·FILE_CONTENT:文件內容,對應Oracle的Blob類型。

      ·REMARK:文件備注。

      文件數據存儲在Blob類型的FILE_CONTENT表字段上,在Spring中采用OracleLobHandler來處理Lob字段(包括 Clob和Blob),由于在程序中不需要引用到oracle數據驅動程序的具體類且屏蔽了不同數據庫處理Lob字段方法上的差別,從而撤除程序在多數據庫移植上的樊籬。

      1.首先數據表中的Blob字段在Java領域對象中聲明為byte[]類型,而非java.sql.Blob類型。

      2.數據表Blob字段在Hibernate持久化映射文件中的type為 org.springframework.orm.hibernate3.support.BlobByteArrayType,即Spring所提供的用戶自定義的類型,而非java.sql.Blob。

      3.在Spring中使用org.springframework.jdbc.support.lob.OracleLobHandler處理Oracle數據庫的Blob類型字段。

      通過這樣的設置和配置,我們就可以象持久化表的一般字段類型一樣處理Blob字段了。

      以上是Spring+Hibernate將文件二進制數據持久化到數據庫的解決方案,而Struts通過將表單中file類型的組件映射為 ActionForm中類型為org.apache.struts.upload. FormFile的屬性來獲取表單提交的文件數據。

      綜上所述,我們可以通過圖 2,描繪出SSH處理文件上傳的方案:


    圖 2 SSH處理文件上傳技術方案

      文件上傳的頁面如圖 3所示:


    圖 3 文件上傳頁面

      文件下載的頁面如圖 4所示:


    圖 4 文件下載頁面

      該工程的資源結構如圖 5所示:


    圖 5 工程資源結構

      工程的類按SSH的層次結構劃分為數據持久層、業務層和Web層;WEB-INF下的applicationContext.xml為Spring的配置文件,struts-config.xml為Struts的配置文件,file-upload.jsp為文件上傳頁面,file-list.jsp為文件列表頁面。

      本文后面的章節將從數據持久層->業務層->Web層的開發順序,逐層講解文件上傳下載的開發過程。
    posted on 2007-04-09 17:21 天外飛仙 閱讀(582) 評論(0)  編輯  收藏 所屬分類: spring

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 猫咪社区免费资源在线观看 | 亚洲成A∨人片在线观看无码| 九九免费观看全部免费视频| 国产v片免费播放| 亚洲av色香蕉一区二区三区蜜桃| 成人最新午夜免费视频| 亚洲人成色777777精品| 国产成人高清精品免费鸭子| 色九月亚洲综合网| 亚洲国产精品自在拍在线播放| 一本到卡二卡三卡免费高| 久久99亚洲综合精品首页| 成人A毛片免费观看网站| 国产AV无码专区亚洲AV毛网站| 女同免费毛片在线播放| 亚洲视频在线免费观看| 亚洲人成网站免费播放| 亚洲国产美女精品久久久| 一本久久综合亚洲鲁鲁五月天 | 美女被免费网站91色| 亚洲av无码国产精品色午夜字幕 | 久久久久精品国产亚洲AV无码| 人禽杂交18禁网站免费| 青青视频免费在线| 美腿丝袜亚洲综合| 24小时在线免费视频| 亚洲国产精品无码观看久久| 亚洲国产a级视频| 无码av免费网站| 人人狠狠综合久久亚洲| 亚洲熟妇中文字幕五十中出| 日韩免费无码一区二区三区| 亚洲男人天堂2018av| 亚洲精品在线视频| 亚洲第一网站免费视频| 国产亚洲美女精品久久久久| 亚洲精品乱码久久久久久按摩| 久久免费看黄a级毛片| 特级毛片A级毛片免费播放| 亚洲人成网址在线观看 | 亚洲精品成人a在线观看|