>  기사  >  백엔드 개발  >  PHP가 문자열을 가로챌 때 중국어 문자가 깨지는 문제에 대한 해결책

PHP가 문자열을 가로챌 때 중국어 문자가 깨지는 문제에 대한 해결책

黄舟
黄舟원래의
2017-11-15 09:46:132869검색

이전 글에서는 PHP 가로채기string 구현과 PHP를 사용하여 중국어 문자열을 가로채는 방법을 설명했는데, 중국어 문자열을 가로채는 경우 문자가 깨지는 경우가 자주 발생하므로 오늘은 그 방법을 소개하겠습니다. PHP에서 문자열을 가로챌 때 중국어 잘못된 문자 문제를 해결하세요!

PHP는 문자열을 가로채기 위해 substr을 사용하고 중국어 왜곡 문제가 발생합니다. mb_substr
사용 예:

mb_substr('截取中文乱码问题测试',0,5, 'utf-8');

구문:

string substr (string string, int start [, int length])
$rest = substr ("abcdef", 1); // returns "bcdef"
$rest = substr ("abcdef", 1, 3); // returns "bcd"

시작이 음수인 경우 반환된 문자열은 문자열 끝의 시작 문자에서 시작됩니다. .

$rest = substr ("abcdef", -1); // returns "f"
$rest = substr ("abcdef", -2); // returns "ef"
$rest = substr ("abcdef", -3, 1); // returns "d"

매개변수 길이가 지정되고 양수인 경우 반환되는 문자열은 시작부터 길이 문자입니다.

매개변수 길이가 주어지고 음수인 경우 반환된 문자열은 문자열 끝의 길이 번째 문자에서 끝납니다.

$rest = substr ("abcdef", 1, -1); // returns "bcde"

영어에는 문제가 없습니다.

$rest = substr ("中国人", 1, -1); // returns "fdsafsda" 就是乱码了

문자를 가로채는 결과는 확실히 우리가 원하는 결과가 아닙니다. 이러한 중국어 왜곡된 PHP substr로 인해 프로그램이 정상적으로 실행되지 않을 수 있습니다.
두 가지 주요 해결 방법이 있습니다

먼저 mbstring 확장 라이브러리의 mb_substr()을 사용하여 가로채서 잘못된 문자가 나타나지 않도록 합니다.
mb_substr()/mb_strcut() 함수를 사용할 수 있습니다. mb_substr()/mb_strcut()의 사용법은 mb_substr()/mb_strcut 끝에 매개변수를 하나 더 추가하여 설정한다는 점을 제외하면 substr()과 유사합니다. ,
하지만 대부분의 서버는 php_mbstring.dll을 열지 않습니다. php.ini에서 php_mbstring.dll을 열어야 합니다.

echo mb_substr("php中文字符encode",0,4,"utf-8");

마지막 인코딩 매개변수를 지정하지 않으면 3바이트가 한자 하나로 사용됩니다. 이는 utf-8문자 집합을 추가하면 한 단어가 사용됩니다. 유닛에 의해 차단되었습니다.
사용시 PHP 파일의 인코딩과 웹 페이지를 표시할 때의 인코딩에 주의하세요. 이 mb_substr 메소드를 사용하려면 문자열의 인코딩을 미리 알아야 하며, 인코딩을 모른다면 판단이 필요합니다. mbstring 라이브러리에서는 문자열 인코딩을 확인할 수 있는 mb_check_encoding도 제공하지만 아직 완벽하지는 않습니다. .

PHP에는 여러 가지 문자열 차단 함수가 포함되어 있으며 그 중 substr 및 mb_substr이 일반적으로 사용됩니다. 전자가 중국어를 처리할 때 GBK는 2길이 단위이고, UTF는 3길이 단위이다. 후자는 인코딩을 지정한 후 한자 1자가 1길이 단위가 된다.

substr은 때때로 중국어의 1/3 또는 절반을 잘라내어 문자가 왜곡되어 표시되는 경우가 있습니다. 상대적으로 말하면 mb_substr이 우리가 사용하기에 더 적합합니다. 그러나 때로는 mb_substr이 그다지 유용하지 않은 것 같습니다. 예를 들어, 작은 그림의 간략한 정보를 표시하려면 한자가 5글자가 넘으면 처음 4글자를 가로채서 "..."만 추가하면 됩니다. 한자는 처리하는데 영어나 숫자는 처리하기가 너무 어렵습니다.

둘째, 차단 기능을 직접 작성하지만 mbstring 확장 라이브러리를 사용하는 것만큼 효율성이 높지 않습니다. 다음은 UTF-8로 인코딩된 문자열을 가로채는 ecshop의 함수입니다.

function sub_str($str, $length = , $append = true)
{
  $str = trim($str);
  $strlength = strlen($str);
  if ($length == || $length >= $strlength)
  {
    return $str; //截取长度等于或大于等于本字符串的长度,返回字符串本身
  }
  elseif ($length < ) //如果截取长度为负数
  {
    $length = $strlength + $length;//那么截取长度就等于字符串长度减去截取长度
    if ($length < )
    {
      $length = $strlength;//如果截取长度的绝对值大于字符串本身长度,则截取长度取字符串本身的长度
    }
  }
  if (function_exists(&#39;mb_substr&#39;))
  {
    $newstr = mb_substr($str, , $length, EC_CHARSET);
  }
  elseif (function_exists(&#39;iconv_substr&#39;))
  {
    $newstr = iconv_substr($str, , $length, EC_CHARSET);
  }
  else
  {
    //$newstr = trim_right(substr($str, , $length));
    $newstr = substr($str, , $length);
  }
  if ($append && $str != $newstr)
  {
    $newstr .= &#39;...&#39;;
  }
  return $newstr;
}

요약:

이 기사에서는 두 가지 예를 사용하여 PHP 가로채기 문자열에 대한 중국어 문제 해결 방법을 소개합니다. 같은 문제를 겪고 있는 친구들이라면 쉽게 해결할 수 있을 것입니다!

관련 추천:

중국어 문자열 가로채기와 중국어 문자열의 문자 수 가져오기의 예


php로 문자열 가로채기 방법 소개

PHP 차단 문자열 함수 substr() 함수 예제 사용법에 대한 자세한 설명

위 내용은 PHP가 문자열을 가로챌 때 중국어 문자가 깨지는 문제에 대한 해결책의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.