有很多朋友下載文件時都是把中文名轉(zhuǎn)換在英文或全數(shù)字的然后再進行下載,下面我來介紹直接利用中文文件名文件下載并且不出現(xiàn)亂碼的解決辦法,代碼如下:
- <?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,應(yīng)該這么定義:
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的結(jié)果與php的urlencode函數(shù)結(jié)果不太相同,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);
- ?>
這樣我們就完全解決了中文文名亂碼這個問題了。
新聞熱點
疑難解答