PHP mb_convert_encoding 获取字符串编码类型实现代码
更新时间:2009年04月26日 01:03:59 作者:
mb_convert_encoding函数就是那个可以自动识别原字符串编码的函数,但在使用中,发现GBK中的某些汉字被它转成了乱码。
后来又在手册上找到了is_utf8函数,这样,再结合iconv函数,我的问题就解决了。下面帖出这个函数:
function is_utf8($string) {
return preg_match('%^(?:
[\x09\x0A\x0D\x20-\x7E] # ASCII
| [\xC2-\xDF][\x80-\xBF] # non-overlong 2-byte
| \xE0[\xA0-\xBF][\x80-\xBF] # excluding overlongs
| [\xE1-\xEC\xEE\xEF][\x80-\xBF]{2} # straight 3-byte
| \xED[\x80-\x9F][\x80-\xBF] # excluding surrogates
| \xF0[\x90-\xBF][\x80-\xBF]{2} # planes 1-3
| [\xF1-\xF3][\x80-\xBF]{3} # planes 4-15
| \xF4[\x80-\x8F][\x80-\xBF]{2} # plane 16
)*$%xs', $string);
} // function is_utf8
如果想深入研究,建议看下PHP手册上的“Multibyte String Functions”这一部分的内容。
复制代码 代码如下:
function is_utf8($string) {
return preg_match('%^(?:
[\x09\x0A\x0D\x20-\x7E] # ASCII
| [\xC2-\xDF][\x80-\xBF] # non-overlong 2-byte
| \xE0[\xA0-\xBF][\x80-\xBF] # excluding overlongs
| [\xE1-\xEC\xEE\xEF][\x80-\xBF]{2} # straight 3-byte
| \xED[\x80-\x9F][\x80-\xBF] # excluding surrogates
| \xF0[\x90-\xBF][\x80-\xBF]{2} # planes 1-3
| [\xF1-\xF3][\x80-\xBF]{3} # planes 4-15
| \xF4[\x80-\x8F][\x80-\xBF]{2} # plane 16
)*$%xs', $string);
} // function is_utf8
如果想深入研究,建议看下PHP手册上的“Multibyte String Functions”这一部分的内容。
相关文章
php中get_cfg_var()和ini_get()的用法及区别
这篇文章主要介绍了php中get_cfg_var()和ini_get()的用法及区别,实例分析了get_cfg_var()和ini_get()函数的区别与使用技巧,需要的朋友可以参考下2015-03-03
在PHP程序中运行Python脚本(接收数据及传参)的方法详解
这篇文章主要为大家详细介绍一下,如何在php程序中运行Python脚本以及如何使用python返回josn数据供php使用,感兴趣的小伙伴可以了解一下2022-09-09
phpmyadmin提示The mbstring extension is missing的解决方法
这篇文章主要介绍了phpmyadmin提示The mbstring extension is missing的解决方法,分析了错误提示的原因与不同平台的解决方法,具有一定的参考借鉴价值,需要的朋友可以参考下2014-12-12
简单介绍win7下搭建apache+php+mysql开发环境
这里给大家介绍的是Win7下搭建“PHP+Apache+MySql”网站运行环境详细方法步骤,十分的细致全面,有需要的小伙伴可以参考下。2015-08-08
PHP使用PhpSpreadsheet操作Excel实例详解
这篇文章主要介绍了PHP使用PhpSpreadsheet操作Excel,结合实例形式详细分析了PHP使用PhpSpreadsheet操作Excel的相关组件下载、函数功能与操作技巧,需要的朋友可以参考下2020-03-03


最新评论