当前位置:Gxlcms > PHP教程 > 解决PHP文件下载时中文文件名乱码的问题

解决PHP文件下载时中文文件名乱码的问题

时间:2021-07-01 10:21:17 帮助过:16人阅读

  1. $filename = "document.txt";
  2. header('Content-Type: application/octet-stream');
  3. header('Content-Disposition: attachment; filename=' . $filename);
  4. print "Hello!";
  5. ?>

用浏览器打开之后,即可下载document.txt。

但是,如果$filename是UTF-8编码的,有些浏览器就无法正常处理了。

例子:

  1. $filename = "中文 文件名.txt";
  2. header('Content-Type: application/octet-stream');
  3. header('Content-Disposition: attachment; filename=' . $filename);
  4. print "Hello!";
  5. ?>

把程序保存成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。

经过试验,发现几种主流浏览器的支持情况如下:

  1. $filename = "中文 文件名.txt";
  2. $encoded_filename = urlencode($filename);
  3. $encoded_filename = str_replace("+", "%20", $encoded_filename);
  4. $ua = $_SERVER["HTTP_USER_AGENT"];
  5. header('Content-Type: application/octet-stream');
  6. if (preg_match("/MSIE/", $ua)) { // bbs.it-home.org
  7. header('Content-Disposition: attachment; filename="' . $encoded_filename . '"');
  8. } else if (preg_match("/Firefox/", $ua)) {
  9. header('Content-Disposition: attachment; filename*="utf8\'\'' . $filename . '"');
  10. } else {
  11. header('Content-Disposition: attachment; filename="' . $filename . '"');
  12. }
  13. print 'ABC';
  14. ?>

人气教程排行