Heim >Backend-Entwicklung >PHP-Problem >Was tun, wenn PHP-Substr verstümmelte Zeichenfolgen abfängt?

Was tun, wenn PHP-Substr verstümmelte Zeichenfolgen abfängt?

藏色散人
藏色散人Original
2021-03-17 09:33:422726Durchsuche

Lösung zum Abfangen verstümmelter Zeichenfolgen durch PHP-Substr: 1. Verwenden Sie zum Abfangen „mb_substr()“ der mbstring-Erweiterungsbibliothek. Die Syntax lautet „mb_substr(string, start position, Character length, „characterkodierung“)“; . Verwenden Sie ecshop. Die darin enthaltene Funktion fängt UTF-8-codierte Zeichenfolgen ab.

Was tun, wenn PHP-Substr verstümmelte Zeichenfolgen abfängt?

Die Betriebsumgebung dieses Artikels: Windows 7-System, PHP 8-Version, DELL G3-Computer

Bei der PHP-Programmentwicklung werden häufig Zeichenfolgenabfangvorgänge durchgeführt, z. B. bei der Ausgabe einer Informationsliste, der Titel sollte nicht zu lang sein und die Artikelzusammenfassung drucken, muss auch eine Reihe von String-Abfangvorgängen durchgeführt werden. Wenn wir auf diese Anforderungen stoßen, denken wir oft darüber nach, die Methode substr() zu verwenden, um dies zu erreichen. Substr() eignet sich besser zum Abfangen rein englischer Zeichenfolgen.

Aber solange chinesische Zeichen in der Zeichenfolge vorkommen, kann es zu verstümmelten chinesischen Zeichen in PHP substr kommen, da jedes chinesische Zeichen aufgrund der chinesischen UTF-8-Codierung 3 Bytes belegt, während GB2312 2 Bytes belegt, Englisch 1 Byte und die Zahl Anzahl der Ziffern wird abgefangen. Ungenau, substr() „sägt“ ein chinesisches Zeichen gewaltsam in zwei Hälften, was dazu führt, dass das gebrochene Zeichen Folgendes zusammenfügt ... zu einem Wort, sodass PHP substr verstümmelte chinesische Zeichen erscheinen.

substr --- Teil des Strings abrufen

Syntax: string substr (string string, int start [, int length])

Beschreibung:

  • substr() gibt einen Teil des Strings zurück, der durch die Parameter start und length angegeben wird.

  • Wenn start eine positive Zahl ist, beginnt die zurückgegebene Zeichenfolge mit dem Startzeichen der Zeichenfolge.

Beispiel:

<?php
$rest = substr ("abcdef", 1); // returns "bcdef"
$rest = substr ("abcdef", 1, 3); // returns "bcd"
?>

Wenn start eine negative Zahl ist, beginnt die zurückgegebene Zeichenfolge mit dem Startwort am Ende der Zeichenfolge.

Beispiel:

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

Wenn die Parameterlänge angegeben ist und eine positive Zahl ist, gibt die zurückgegebene Zeichenfolge Längenzeichen vom Anfang an zurück.
Wenn der Parameter Länge angegeben ist und es sich um eine negative Zahl handelt, endet die zurückgegebene Zeichenfolge beim längenstärksten Zeichen vom Ende der Zeichenfolge.

Beispiel:

<?php
$rest = substr ("abcdef", 1, -1); // returns "bcde"
?>

Es gibt kein Problem mit Englisch

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

Das Ergebnis des Abfangens von Zeichen ist definitiv nicht das gewünschte Ergebnis. Diese Situation mit verstümmelten chinesischen PHP-Substrängen kann zu einer Fehlfunktion des Programms führen. Es gibt zwei Hauptlösungen:

1. Verwenden Sie zum Abfangen mb_substr() der mbstring-Erweiterungsbibliothek, damit keine verstümmelten Zeichen angezeigt werden.

Sie können die Funktion mb_substr()/mb_strcut() verwenden. Die Verwendung von mb_substr()/mb_strcut() ist ähnlich wie bei substr(), außer dass am Ende von mb_substr()/mb_strcut ein weiterer Parameter hinzugefügt wird Um die Zeichenfolge festzulegen, öffnen die meisten Server php_mbstring.dll nicht. Sie müssen php_mbstring.dll in php.ini öffnen.

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

Wenn der letzte Kodierungsparameter nicht angegeben ist, werden drei Bytes als ein chinesisches Zeichen verwendet. Dies ist das Merkmal der UTF-8-Kodierung. Wenn die UTF-8-Zeichensatzbeschreibung hinzugefügt wird, wird sie in Einheiten von abgefangen ein Wort von.

Achten Sie bei der Verwendung auf die Kodierung der PHP-Datei und die Kodierung beim Anzeigen der Webseite. Um diese mb_substr-Methode zu verwenden, müssen Sie die Codierung der Zeichenfolge im Voraus kennen. Wenn Sie die Codierung nicht kennen, müssen Sie sie beurteilen. Die mbstring-Bibliothek bietet auch mb_check_encoding, um die Zeichenfolgencodierung zu überprüfen .

PHP verfügt über mehrere Funktionen zum Abfangen von Zeichenfolgen, unter denen häufig substr und mb_substr verwendet werden. Wenn ersteres Chinesisch verarbeitet, beträgt GBK 2 Längeneinheiten und UTF 3 Längeneinheiten. Nachdem letzteres die Codierung angegeben hat, ist ein chinesisches Zeichen 1 Längeneinheit.

substr schneidet manchmal 1/3 Chinesisch oder die Hälfte Chinesisch ab und zeigt verstümmelte Zeichen an. Relativ gesehen ist mb_substr für uns besser geeignet. Aber manchmal scheint mb_substr nicht so nützlich zu sein. Wenn ich beispielsweise die kurzen Informationen eines kleinen Bildes anzeigen möchte, sind 5 chinesische Zeichen genau richtig. Wenn es mehr als 5 Zeichen sind, fangen Sie einfach die ersten 4 ab und fügen Sie „…“ hinzu Chinesisch, aber bei der Verarbeitung von Englisch oder Zahlen ist dieser Abfang zu kurz.

2. Schreiben Sie die Abfangfunktion selbst, aber die Effizienz ist nicht so hoch wie die Verwendung der MBstring-Erweiterungsbibliothek. Das Folgende ist eine Funktion in ecshop, die in UTF-8 codierte Zeichenfolgen abfängt.

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

Okay, das ist alles, was in diesem Artikel beschrieben wird. Der obige Code ist auch sehr einfach. Wenn Sie etwas nicht verstehen, hinterlassen Sie mir bitte eine Nachricht Sie so schnell wie möglich.

Empfohlenes Lernen: „PHP-Video-Tutorial

Das obige ist der detaillierte Inhalt vonWas tun, wenn PHP-Substr verstümmelte Zeichenfolgen abfängt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn