项目之前下载的PDF出现了乱码的问题。乱码问题的本质就是字符编码的差异,解决的思路也是通过转换编码来实现。
$search = array('*','$','\\','/',"'",'"','*','?',':','<','>','|',' ');
$PHName=str_replace($search, '_', $policy_info['PHName']);
$policy_number=$policy_info['PolicyNumber'].'_'.$PHName;
$policy_number=iconv('UTF-8','GBK//IGNORE',$policy_number);
该段代码有两步,第一步是转换一些特殊字符,转换一些特殊字符是很有必要的,比如客户传过来的的文件名是"zhangsan/lisi",最后的输出的结果可能是"lisi.pdf",因为"/"在路径是作为目录的分隔符,所以结果并不如我们预期所想。最后一步才是转换字符编码,将UTF-8转换为中文编码即可,因为很多文件或浏览器系统一般不适用utf-8的编码方式。函数用法,查询即可。