300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > PHP判断字符串编码是否为utf-8的程序代码

PHP判断字符串编码是否为utf-8的程序代码

时间:2021-08-05 00:09:58

相关推荐

PHP判断字符串编码是否为utf-8的程序代码

php教程|php手册

php字符串,utf-8编码

php教程-php手册

我们以前常用mb_detect_encoding()此函数检测字符编码,代码如下:

扫号码源码,ubuntu 无系统栏,Tomcat进程在哪里调,爬虫脚本亚马逊,红鸟中文php编程,open seo 扩展lzw

//判断字符串是什么编码 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,当字符串较短时,检测结果产生偏差的可能性很大,怎么解决呢,我的办法是:

类似微博源码,ubuntu 进程 预分配,python爬虫标签筛选,wamp php网页,iprospect的SEOlzw

$encode = mb_detect_encoding($keytitle, array(‘ASCII’,’GB2312′,’GBK’,’UTF-8′);

自适应 全屏页面 源码,vscode代码版本控制,ubuntu搭建wifi,生产环境用tomcat,sqlite支持的数据格式,爬虫工程师如何转数据分析,php 输出数组元素,广西智能seo代运营,叉车网站源码,易企秀赠送模板lzw

参数分别是:被检测的输入变量、编码方式的检测顺序(一旦为真,后面自动忽略)、strict模式,对编码检测的顺序进行调整,将最大可能性放在前面,这样减少被错误转换的机会.

上面办法还是解决不了,下面又找到了一个解决方法,代码如下:

function is_utf8($string){return !strlen(preg_replace( ,[\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. ,sS,\, $string));}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。