1. 程式人生 > >js 檔案自動下載,而不是自動開啟 Content-disposition

js 檔案自動下載,而不是自動開啟 Content-disposition

Content-disposition 是 MIME 協議的擴充套件,MIME 協議指示 MIME 使用者代理如何顯示附加的檔案。當 Internet Explorer 接收到頭時,它會啟用檔案下載對話方塊,它的檔名框自動填充了頭中指定的檔名。(請注意,這是設計導致的;無法使用此功能將文件儲存到使用者的計算機上,而不向使用者詢問儲存位置。)  

        服務端向客戶端遊覽器傳送檔案時,如果是瀏覽器支援的檔案型別,一般會預設使用瀏覽器開啟,比如txt、jpg等,會直接在瀏覽器中顯示,如果需要提示使用者儲存,就要利用Content-Disposition進行一下處理,關鍵在於一定要加上attachment:

Response.AppendHeader("Content-Disposition","attachment;filename=FileName.txt");

備註:這樣瀏覽器會提示儲存還是開啟,即使選擇開啟,也會使用相關聯的程式比如記事本開啟,而不是IE直接打開了。

Content-Disposition就是當用戶想把請求所得的內容存為一個檔案的時候提供一個預設的檔名。具體的定義如下:

content-disposition = “Content-Disposition” “:”

disposition-type *( “;” disposition-parm )

disposition-type = “attachment” | disp-extension-token

disposition-parm = filename-parm | disp-extension-parm

filename-parm = “filename” “=” quoted-string

disp-extension-token = token

disp-extension-parm = token “=” ( token | quoted-string )

那麼由上可知具體的例子:

Content-Disposition: attachment; filename=“filename.xls”

       當然filename引數可以包含路徑資訊,但User-Agnet會忽略掉這些資訊,只會把路徑資訊的最後一部分做為檔名。當你在響應型別為application/octet- stream情況下使用了這個頭資訊的話,那就意味著你不想直接顯示內容,而是彈出一個”檔案下載”的對話方塊,接下來就是由你來決定“開啟”還是“儲存” 了。

注意事項:

1.當代碼裡面使用Content-Disposition來確保瀏覽器彈出下載對話方塊的時候。 response.addHeader("Content-Disposition","attachment");一定要確保沒有做過關於禁止瀏覽器快取的操作。如下:

response.setHeader("Pragma", "No-cache"); 
response.setHeader("Cache-Control", "No-cache"); 
response.setDateHeader("Expires", 0);