在使用PHP处理字符串时,我们经常会碰到字符编码转换的问题,一般都是用iconv进行转码的,但是iconv也不是万能的,碰到一些生僻字就会无法转换,如果配置了第二个参数,可以稍微弥补一下默认缺陷,不至于无法转换,用法如下
iconv(“UTF-8″,”GB2312//IGNORE”,$data) ;
这样碰到生僻字转换失败时,它就会忽略失败,继续转换下面的内容。
还有一个转码函数:mb_convert_encoding,他的转换成功率比iconv高,但是有利就有弊,他的转码速率比较低,另外这个函数还可以省略第三个参数,自动识别内容编码,但是影响效率,还需要注意的是,mb_convert_encoding和iconv参数顺序不一样,一定要注意。
附两个函数简单的用法:
iconv
string iconv ( string $in_charset , string $out_charset , string $str )
第一个参数:内容原的编码
第二个参数:目标编码
第三个参数:要转的字符串
函数返回字符串
<?php
$instr = ‘测试’;
// GBK转UTF-8
$outstr = iconv(‘GBK’,'UTF-8′,$instr);
?>
mb_convert_encoding
string mb_convert_encoding ( string $str , string $to_encoding [, mixed $from_encoding ] )
第一个参数:要处理的字符串
第二个参数:目标编码
第三个参数:内容原编码
<?php
$instr = '测试';
// GBK转UTF-8
$outstr = mb_convert_encoding($instr,'UTF-8','GBK',);
?>
如果系统对效率要求不是很高、系统资源充足且要转码的内容常有生僻字出现的情况下建议选用mb_convert_encoding比较保险。