php實(shí)現(xiàn)中文文件名文件下載
來源:程序員人生 發(fā)布時(shí)間:2014-04-02 10:45:08 閱讀次數(shù):2929次
有很多朋友下載文件時(shí)都是把中文名轉(zhuǎn)換在英文或全數(shù)字的然后再進(jìn)行下載,下面我來介紹直接利用中文文件名文件下載并且不出現(xiàn)亂碼的解決辦法,代碼如下:
- <?php
- $filename = "中文 文件名.txt";
- header('Content-Type: application/octet-stream');
- header('Content-Disposition: attachment; filename=' . $filename);
- print "Hello!";
- ?>
把程序保存成UTF-8編碼再訪問,IE6下載的文件名就會(huì)亂碼,FF3下下載的文件名就只有“中文”兩個(gè)字,Opera 9下一切正常,輸出的header實(shí)際上是這樣子:
Content-Disposition: attachment; filename=中文 文件名.txt
其實(shí)按照RFC2231的定義,多語(yǔ)言編碼的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后面的等號(hào)之前要加 * ,filename的值用單引號(hào)分成三段,分別是字符集(utf8)、語(yǔ)言(空)和urlencode過的文件名,最好加上雙引號(hào),否則文件名中空格后面的部分在Firefox中顯示不出來.
注意:urlencode的結(jié)果與php的urlencode函數(shù)結(jié)果不太相同,php的urlencode會(huì)把空格替換成+,而這里需要替換成%20
實(shí)例代碼如下:
- <?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);
- ?>
這樣我們就完全解決了中文文名亂碼這個(gè)問題了。
生活不易,碼農(nóng)辛苦
如果您覺得本網(wǎng)站對(duì)您的學(xué)習(xí)有所幫助,可以手機(jī)掃描二維碼進(jìn)行捐贈(zèng)