php實現中文文件名文件下載
來源:程序員人生 發布時間:2014-04-02 10:45:08 閱讀次數:2915次
有很多朋友下載文件時都是把中文名轉換在英文或全數字的然后再進行下載,下面我來介紹直接利用中文文件名文件下載并且不出現亂碼的解決辦法,代碼如下:
- <?php
- $filename = "中文 文件名.txt";
- header('Content-Type: application/octet-stream');
- header('Content-Disposition: attachment; filename=' . $filename);
- print "Hello!";
- ?>
把程序保存成UTF-8編碼再訪問,IE6下載的文件名就會亂碼,FF3下下載的文件名就只有“中文”兩個字,Opera 9下一切正常,輸出的header實際上是這樣子:
Content-Disposition: attachment; filename=中文 文件名.txt
其實按照RFC2231的定義,多語言編碼的Content-Disposition,應該這么定義:
Content-Disposition: attachment; filename*="utf8''%E4%B8%AD%E6%96%87%20%E6%96%87%E4%BB%B6%E5%90%8D.txt"
即:filename后面的等號之前要加 * ,filename的值用單引號分成三段,分別是字符集(utf8)、語言(空)和urlencode過的文件名,最好加上雙引號,否則文件名中空格后面的部分在Firefox中顯示不出來.
注意:urlencode的結果與php的urlencode函數結果不太相同,php的urlencode會把空格替換成+,而這里需要替換成%20
實例代碼如下:
- <?php
- $file = "/tmp/中文名.tar.gz";
- $filename = basename($file);
- header("Content-type: application/octet-stream");
-
- $ua = $_SERVER["HTTP_USER_AGENT"];
- $encoded_filename = urlencode($filename);
- $encoded_filename = str_replace("+", "%20", $encoded_filename);
- if (preg_match("/MSIE/", $ua)) {
- header('Content-Disposition: attachment; filename="' . $encoded_filename . '"');
- } else if (preg_match("/Firefox/", $ua)) {
- header("Content-Disposition: attachment; filename*="utf8''" . $filename . '"');
- } else {
- header('Content-Disposition: attachment; filename="' . $filename . '"');
- }
- header('Content-Disposition: attachment; filename="' . $filename . '"');
- header("Content-Length: ". filesize($file));
- readfile($file);
- ?>
這樣我們就完全解決了中文文名亂碼這個問題了。
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈