PHP에서 잘못된 문자를 중국어로 가로채는 방법: 먼저 ASCII 인코딩과 중국어 인코딩의 일관되지 않은 이진 범위를 사용하여 구분한 다음 [substr()] 함수를 사용하여 문자열을 가로채세요.
PHP 중국어 왜곡 문자 가로채기에 대한 솔루션:
구현 원칙은 여전히 상대적으로 간단합니다. 주로 ASCII 인코딩과 중국어 인코딩의 일관되지 않은 이진 범위를 사용하여 구별한 다음 substr()을 통해 문자열을 가로채는 기능으로 구현됩니다.
내가 작성한 코드는 다음과 같습니다. 참고: 다른 인코딩의 경우 독자가 수동으로 다른 인코딩을 지원하도록 기능을 변경할 수 있습니다.
<?php header('content-type:text/html;charset=utf-8;'); $str = '利要a-符e:r ttnx节小-子s区。vh;peh。例t来个oe体字n代gb节看t通c eu是的soS至什tna过码 t;Ie看C实e/,字le A来具8y么a)n=于ndg是r于 0tmt现码 e0ssf8单下s(uo别e的以ieh过aatx和t接要u几这看 nsw Ihrr用字 mgtts上就eg cAei的nwo码e跳h,t编'; /* *在某篇文章中截取一段字符串,多余的用省略号...表示,并且防止中文乱码 *$param1 string要截取的字符串 $str 注意:这里是utf-8编码 *$param2 int截取字符串的长度 $len *返回值 成功返回所要截取的字符串,失败为空 */ function str($str='',$len=0){ //检查参数 if(!is_string($str) || !is_int($len)){ return ''; } $length = strlen($str); if($length <= 0 ){ return ''; } if($len>=$length){ return $str; } //初始化,统计字符串的个数, $count = 0; for($i=0;$i<$length;$i++){ //达到个数跳出循环,$i即为要截取的长度 if($count == $len){ break; } $count++; //ord函数是获取字符串的ASCII编码,大于等于十六进制0x80的字符串即为中文字符串 if(ord($str{$i}) >= 0x80){ $i +=2;//中文编码的字符串的长度再加2 } } //如果要截取的个数超过了字符串的总个数,那么我们返回全部字符串,不带省略号 if($len > $count){ return $str; }else{ return substr($str,0,$i).'...'; } }
위 코드의 구현은 0x80 이하의 1바이트 문자의 ASCII 코드를 사용하는 것입니다. 건너뛸 바이트 수는 특정 인코딩에 따라 다릅니다.
관련 무료 학습 권장 사항: php 프로그래밍(동영상)
위 내용은 PHP 중국어가 잘못된 문자를 가로채면 어떻게 해야 할까요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!