1 / 5
文档名称:

PHP中文乱码解决方案.docx

格式:docx   大小:16KB   页数:5页
下载后只包含 1 个 DOCX 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

PHP中文乱码解决方案.docx

上传人:bb21547 2019/3/3 文件大小:16 KB

下载得到文件列表

PHP中文乱码解决方案.docx

文档介绍

文档介绍:PHP中文乱码解决方案 PHP+MYSQL做网站开发通常都会碰到浏览器输出中文字符时乱码,这个问题的原因主要是因为HTML内容编码,PHP文件编码和MySQL数据库编码这三者不一致造成的。今天我们来具体探讨下出现中文乱码后的解决方案。汉字乱码真是一个悲催的事情,JAVA讨厌汉字,PHP也不喜欢汉字; Java乱码最终使用了spring给出的过滤器来过滤,处处过滤,其实影响了速度,不过没有办法,汉字就是W国首先不考虑的事情; 想不到PHP也是乱码处处在,当你使用亲兄弟MySQL的时候,汉字显得那么亲切,从未考虑过他会变成天书;不过为了和其他其他交互,把PHP的手伸到SQLSERVER的时候,乱码来了,原因是第三方系统用的GBK编码; 哎,转换吧; 1,PHP自带的转换函数ICONV,一个高大上的函数; 代码如下: stringiconv(string$in_charset,string$out_charset,string$str) 使用DEMO: 代码如下: $text="ThisistheEurosymbol'€'."; echo'Original:',$text,PHP_EOL; echo'TRANSLIT:',iconv("UTF-8","ISO-8859-1//TRANSLIT",$text),PHP_EOL; echo'IGNORE:',iconv("UTF-8","ISO-8859-1//IGNORE",$text),PHP_EOL; echo'Plain:',iconv("UTF-8","ISO-8859-1",$text),PHP_EOL; ?> 大家都推荐的函数,不过使用之后无法转换,没有错误,字符也没有转换,NO! 2,另辟蹊径,还有一个大家质疑效率不高的函数,不过无论如何,先实现再考虑其他三代码如下: //检查该函数是否可用 echofunction_exists('mb_convert_encoding'); //检测当前编码 echomb_detect_encoding($val,"GBK,GB2312,UTF-8"); //转换编码,把CP936(就是GBK)转换成UTF-8 $v=mb_convert_encoding($val,"UTF-8","CP936"); 结果成功了; 好吧,先用着吧,为了转换数据库查询的结果集,制作一个转换函数: 1,函数“乱码克星”: 代码如下: //$fContents字符串//$from字符串的编码//$to要转换的编码 functionauto_charset($fContents,$from='gbk',$to='utf-8'){ $from=strtoupper($from)=='UTF8'?'utf-8':$from; $to=strtoupper($to)=='UTF8'?'utf-8':$to; if(strtoupper($from)===strtoupper($to)||empty($fContents)||(is_scalar($fContents)&&!is_string($fContents))){ //如果编码相同或者非字符串标量则不转换 return$fContents; } if(is_string(