PHP判断字符串编码是否为utf-8的程序代码
发布:smiling 来源: PHP粉丝网 添加日期:2014-07-05 15:15:02 浏览: 评论:0
我们以前常用mb_detect_encoding()此函数检测字符编码,代码如下:
- //判断字符串是什么编码
- if ($tag === mb_convert_encoding(mb_convert_encoding($tag, "GB2312", "UTF-8"), "UTF-8", "GB2312")) {
- }
- else {//如果是gb2312 的就转换为utf8的
- $tag = mb_convert_encoding($tag, 'UTF-8', 'GB2312');
- }
$keytitle = “%D0%BE%C6%AC”;时,检测结果却是UTF-8.这个bug其实不算是bug,写程序时也不应当过于依赖mb_detect_encoding,当字符串较短时,检测结果产生偏差的可能性很大,怎么解决呢,我的办法是:
$encode = mb_detect_encoding($keytitle, array('ASCII','GB2312′,'GBK','UTF-8');
参数分别是:被检测的输入变量、编码方式的检测顺序(一旦为真,后面自动忽略)、strict模式,对编码检测的顺序进行调整,将最大可能性放在前面,这样减少被错误转换的机会.
上面办法还是解决不了,下面又找到了一个解决方法,代码如下:
- // Returns true if $string is valid UTF-8 and false otherwise.
- function is_utf8($word)
- {
- if (preg_match("/^([".chr(228)."-".chr(233)."]{1}[".chr(128)."-".chr(191)."]{1}[".chr(128)."-".chr(191)."]{1}){1}/",$word) == true || preg_match("/([".chr(228)."-".chr(233)."]{1}[".chr(128)."-".chr(191)."]{1}[".chr(128)."-".chr(191)."]{1}){1}$/",$word) == true || preg_match("/([".chr(228)."-".chr(233)."]{1}[".chr(128)."-".chr(191)."]{1}[".chr(128)."-".chr(191)."]{1}){2,}/",$word) == true)
- {
- return true;
- }
- else
- {
- return false;
- }
- } // function is_utf8
Tags: PHP字符串 utf-8编码
相关文章
- ·PHP 字符串长度判断效率更高的方法(2020-09-27)

推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)