您的位置:首页 >> LNMPA >> 当file_get_contents遇到中文文件名
当file_get_contents遇到中文文件名
[ 孤狼 | 2015-02-11 16:42:22 | LNMPA ]


当file_get_contents遇到中文文件名


       今天遇到一个很棘手的问题,客户用ftp向服务器传了一个文件,但是却无法被程序识别.查看代码后,没有发现问题,最后重演流程发现,客户上传的文件是中文命名的.于是小做测试发现,file_get_contents函数尽然不支持中文文件名文件.

       原有代码如下:

              $filename='哈.txt';

               echo file_get_contents('./'.$filename);

      执行以后显示结果:

18011370332551.jpg

       悲剧开始.


       之后试了不少判断方法,显示怀疑是不是编码问题,文件编码,代码编码一遍遍的排查,可是都是很匹配的啊.

       之后查了相关资料却没有找到,于是google了一下发现有人遇到这个问题,说是系统编码的问题,于是开始对文件名进行转码.

       文件用的是utf-8编码,但是系统默认为gbk.所以先把文件名转换gbk然后再读取.

       

              $filename='哈.txt';

               $filename=iconv('utf-8','gb2312',$filename);

               //echo file_get_contents(mb_convert_encoding('./哈.txt', 'gbk', 'utf-8')); (另一种方法)

               echo file_get_contents('./'.$filename);


       测试结果:

65741370332552.png

       读取成功.

       

       OK,大功告成.


      推测:

               由file_get_contents函数的功能可以推断,file系列的函数可能也会遇到这个问题,所以以后在使用的时候也要考虑到操作系统的编码问题.

97241370332553.gif


转载请注明出处:http://gl.paea.cn/lnmpa/content/2015/02/11/63.html