隨筆-57  評論-117  文章-1  trackbacks-0

               我們都知道普通的文件上傳是通過表單進(jìn)行文件上傳的,還不能達(dá)到異步上傳的目的。通過使用某些技術(shù)手段,比如jquery form.js可以達(dá)到異步上傳的目的,但最重要的問題在于,它不能夠進(jìn)行多個文件的上傳。如果你要上傳多個文件,必須一個一個地上傳,同時還要在界面上處理當(dāng)上傳完一個文件之后,下一個文件上傳框的問題。
              現(xiàn)在我們有了一個更多的運行,即使用swfupload進(jìn)行多文件異步上傳。顧名思義,它是一個flash的上傳工具,但在界面上的表現(xiàn)形式使它和普通的html元素一樣,沒有復(fù)雜的展現(xiàn),就一個普通的上傳框,即可達(dá)到想要目的。

              關(guān)于swfupload的使用這里自不必多,這里主要介紹的是解決在java web開發(fā)過程中經(jīng)常碰到的驗證失敗的問題。這是因為flash在上傳的時候使用的是和瀏覽器不同的會話,flash的SWFUpload上傳利用socket套接字進(jìn)行通信,所以導(dǎo)致session和原來上一次的會話不同,導(dǎo)致session丟失。這樣就導(dǎo)致服務(wù)器在驗證時自然被認(rèn)為是新會話,從而驗證不能通過,導(dǎo)致上傳不能成功了。
              解決問題的方法,就是讓flash在上傳文件的時候帶上同在一個界面的session標(biāo)識,這通常是修改其中的upload_url來達(dá)到我們的目的,修改如下所示:

          upload_url: "/admin/infobuild/image/upload.action;jsessionid=${pageContext.session.id }"

          上面這句話,必須放到j(luò)sp界面上,因為里面使用到了JavaWeb的語法,當(dāng)然這可以修改,通過將<%=session.getId()%> 或 ${pageContext.session.id } 放到特殊的js變量中,可以達(dá)到隱藏變量的目的。比如如下的代碼:
          <!-- 這句要房子jsp頁面中的script腳本中,或是放在servlet的response.getWriter()流中的script腳本中;總之要在swfupload 的js引入之前執(zhí)行 -->
          window["sessionId"]="${pageContext.session.id}"; 
          <!-- 這句話就可以在引入的js中使用 -->
          upload_url: Gtip.util.addContextPath("/admin/infobuild/image/upload.action;jsessionId"  + "=" + window["sessionId"]),

          以上方案是解決在jsp頁面中解決的取值java的變量值;

          如上代碼的第一句放到j(luò)sp文件中,如jsp的公共include文件中。下面一句就放到j(luò)s文件中,如引入的upload.js文件當(dāng)中。
              但以上代碼還存在一個問題,就是默認(rèn)的sessionName問題。在tomcat或者其它j2ee容器,默認(rèn)的sessionName也是 jsessionId。如果我們修改了sessionName如通過tomcat的server.xml修改session_cookie_name,這樣默認(rèn)的sessionName就是我們修改之后的了。解決此問題,需要再加一個參數(shù)設(shè)置才可,如下所示:

           

          <!-- 這三行放在include 導(dǎo)入的那個jsp的頁面中 -->
          window["contextPath"] = "${pageContext.request.contextPath}";
          window["sessionId"] = "${pageContext.session.id}";
          window["sessionName"] = "jsessionId";
           
          // js中使用jsp中設(shè)置的window的變量值
          upload_url: addContextPath("/admin/infobuild/image/upload.action;" + window["sessionName"] + "=" + window["sessionId"])

          以上代碼的前三行放到公共的include.jsp中,最后一行放到公共的upload.js中。這樣即可滿足最終要求了。
          不過有一點不好的即是,在部署環(huán)境中時,如果部署環(huán)境修改了sessionName,則必須在此include.jsp中修改一個具體的sessionName才可。

          轉(zhuǎn)載請標(biāo)明出處:i flym
          本文地址:http://www.iflym.com/index.php/code/201108190001.html



          作者:hoojo
          出處:
          blog:http://blog.csdn.net/IBM_hoojo
                   http://hoojo.cnblogs.com
          本文版權(quán)歸作者和博客園共有,歡迎轉(zhuǎn)載,但未經(jīng)作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責(zé)任的權(quán)利。


          版權(quán)所有,轉(zhuǎn)載請注明出處 本文出自:
          分享道版權(quán)所有,歡迎轉(zhuǎn)載,轉(zhuǎn)載請注明出處,謝謝
          posted on 2012-05-11 14:14 hoojo 閱讀(2972) 評論(0)  編輯  收藏 所屬分類: Ajax【富客戶端技術(shù)】HTML/CSSJavaEEJsp/Servlet
          主站蜘蛛池模板: 盱眙县| 云梦县| 西平县| 罗城| 颍上县| 麦盖提县| 宣武区| 淮阳县| 博乐市| 安福县| 丰宁| 鄂州市| 贺兰县| 海伦市| 舞钢市| 常德市| 安义县| 于都县| 海城市| 五河县| 牙克石市| 巴彦淖尔市| 南岸区| 靖安县| 秀山| 蓝田县| 醴陵市| 客服| 沅江市| 武邑县| 鄂州市| 桑日县| 肇东市| 易门县| 巴里| 通化县| 铜鼓县| 宁德市| 隆回县| 宝丰县| 汝州市|