1. 程式人生 > >jxl 寫 Excel 檔案並下載(寫標頭檔案)

jxl 寫 Excel 檔案並下載(寫標頭檔案)

使用servlet來下載檔案,其原理非常簡單,只要得到檔案的輸入流(或相應位元組),然後寫輸出流即可。現就其中的幾個細節問題展開:
1. MIME型別的設定:
Web 瀏覽器使用 MIME 型別來識別非 HTML 文件,並決定如何顯示該文件內的資料。
例如EXCEL檔案的 MIME 型別是 "application/vnd.ms-excel "。要用servlet 來開啟一個 EXCEL 文件,需要將 response 物件中 header 的 contentType 設定成“application/vnd.ms-excel ”。
response.setContentType(contentType);

2. Content disposition
HTTP response header中的content-disposition 允許 servlet 指定文件表示的資訊。使用這種header ,你就可以將文件指定成單獨開啟(而不是在瀏覽器中開啟),還可以根據使用者的操作來顯示。
如果使用者要儲存文件,你還可以為該文件建議一個檔名。這個建議名稱會出現在 Save As 對話方塊的“檔名”欄中。如果沒有指定,則對話方塊中就會出現 servlet 的名字。
servlet 中,將 header 設定成下面這樣:
response.setHeader("Content-disposition","attachment;filename="+ "Example.xls" );

response.setHeader("Content-Disposition", "inline; filename="fliename)
點選開啟會在ie中開啟。


需要說明的有三點:
Ø 中文檔名需要進行iso8859-1轉碼方可正確顯示:
fileName = new String(fileName.getBytes("GBK"),"iso8859-1");
Ø 傳遞的檔名,需要包含字尾名(如果此檔案有後綴名),否則丟失檔案的屬性,而不能自行選擇相關程式開啟。
Ø 有下載前詢問(是開啟檔案還是儲存到計算機)和通過IE瀏覽器直接選擇相關應用程式外掛開啟兩種方式,前者如上程式碼所示,後者如下:
response.setHeader("Content-disposition","filename="+ "Example.xls" );
3. 在研究檔案的上傳及下載過程中,有幾點體會
程式的I/O操作往往是效能的瓶頸所在,java io定義了兩個基本的抽象類:InputStream和OutputStream,對於不同的資料型別比如磁碟,網路又提供了不同的實現,java.io也提供了一些緩衝流(BufferedStream),使硬碟可以很快的讀寫一大塊的資料, 而Java基本的I/O類一次只能讀寫一個位元組,但緩衝流(BufferedStream)可以一次讀寫一批資料,,緩衝流(Buffered Stream)大大提高了I/O的效能。所以:
Ø小塊小塊的讀寫資料會非常慢,因此,儘量大塊的讀寫資料
Ø使用BufferedInputStream和BufferedOutputStream來批處理資料以提高效能
Ø物件的序列化(serialization)非常影響I/O的效能,儘量少用