Maison  >  Article  >  développement back-end  >  Comment résoudre le problème chinois tronqué de php mbsubstr

Comment résoudre le problème chinois tronqué de php mbsubstr

藏色散人
藏色散人original
2021-09-01 10:07:042247parcourir

Solution au code tronqué chinois php mbsubstr : 1. Utilisez mb_substr() de la bibliothèque d'extension mbstring pour intercepter ; 2. Résolvez le problème du code tronqué via la méthode personnalisée "function sub_str(){...}".

Comment résoudre le problème chinois tronqué de php mbsubstr

L'environnement d'exploitation de cet article : système Windows 7, version PHP 7.1, ordinateur Dell G3

Comment résoudre le problème chinois déformé de php mbsubstr ?

PHP utilise substr pour intercepter les chaînes et le chinois un problème tronqué se produit. Utilisez mb_substr

Exemple :mb_substr('Interception of Chinese garbled code problem test',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"

Si start est un nombre négatif, la chaîne renvoyée commencera à partir du caractère de début à la fin de la chaîne.

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

Si la longueur du paramètre est donnée et qu'il s'agit d'un nombre positif, la chaîne renvoyée sera composée de caractères de longueur depuis le début.

Si le paramètre length est donné et qu'il s'agit d'un nombre négatif, la chaîne renvoyée se terminera à la longueur du ème caractère à partir de la fin de la chaîne.

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

Il n'y a pas de problème avec l'anglais. Nous avons testé un chinois

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

Le résultat de l'interception de caractères n'est certainement pas le résultat que nous souhaitons. Cette situation de sous-titre PHP tronqué en chinois peut empêcher le programme de fonctionner normalement.

Il existe deux solutions principales :

1. Utilisez mb_substr() de la bibliothèque d'extension mbstring pour intercepter, et les caractères tronqués n'apparaîtront pas.

Vous pouvez utiliser la fonction mb_substr()/mb_strcut(). L'utilisation de mb_substr()/mb_strcut() est similaire à substr(), sauf qu'un paramètre supplémentaire doit être ajouté à la fin de mb_substr()/mb_strcut. pour définir l'encodage de la chaîne. ,

Mais la plupart des serveurs n'ouvrent pas php_mbstring.dll Vous devez ouvrir php_mbstring.dll dans php.ini.

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

Si le dernier paramètre d'encodage n'est pas spécifié, trois octets seront utilisés comme un caractère chinois. C'est la caractéristique de l'encodage utf-8. Si la description du jeu de caractères utf-8 est ajoutée, elle sera interceptée en unités de. un mot de.

Lors de son utilisation, faites attention à l'encodage du fichier php et à l'encodage lors de l'affichage de la page web. Pour utiliser cette méthode mb_substr, vous devez connaître l'encodage de la chaîne à l'avance. Si vous ne connaissez pas l'encodage, vous devez juger. La bibliothèque mbstring fournit également mb_check_encoding pour vérifier l'encodage de la chaîne, mais ce n'est pas encore parfait. .

PHP est livré avec plusieurs fonctions d'interception de chaînes, parmi lesquelles substr et mb_substr sont couramment utilisées. Lorsque le premier traite le chinois, GBK correspond à 2 unités de longueur et UTF à 3 unités de longueur. Après que le second ait spécifié le codage, un caractère chinois correspond à 1 unité de longueur.

substr coupe parfois 1/3 du chinois ou la moitié du chinois et affiche des caractères tronqués. Relativement parlant, mb_substr nous convient mieux. Mais parfois, mb_substr n'est pas si simple à utiliser. Par exemple, si je souhaite afficher les brèves informations d'une petite image, 5 caractères chinois suffisent. S'il y a plus de 5 caractères, interceptez simplement les 4 premiers et ajoutez "...". Cela ne pose aucun problème lors du traitement. Chinois, mais lors du traitement de l'anglais ou des chiffres, cette interception sera trop courte.

Recommandé : "Tutoriel vidéo PHP"

Deuxièmement, écrivez vous-même la fonction d'interception, mais l'efficacité n'est pas aussi élevée que l'utilisation de la bibliothèque d'extension mbstring. Ce qui suit est une fonction d'ecshop qui intercepte les chaînes codées en UTF-8.

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;
}

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn