Heim >Backend-Entwicklung >PHP-Tutorial >Der Abgleich regulärer Ausdrücke enthält Sonderzeichen

Der Abgleich regulärer Ausdrücke enthält Sonderzeichen

WBOY
WBOYOriginal
2016-08-04 09:19:401615Durchsuche

<code>    $info = array(
        "https://segmentfault.com/q/1010000003711515",
        "http://www.baidu.com?admin.php&jasdhjas=asjd",
        'php $a=0; echo "abc";',
        "假如这是第三个....*^%$#@!()[]{}",
        );
    foreach ($info as $key => $value) {
        $message = "https://segmentfault.com/q/1010000003711515";
        $preg = "/^".$value."$/";
        if (preg_match($preg, $message)) {
            echo '匹配成功';
            break;
        }
    }</code>

durchläuft das Array $info, fügt /^ vor und nach jeder Zeichenfolge hinzu und $/ wird zu einem regulären Ausdruck, der mit dem bereitgestellten $message übereinstimmt, aber aufgrund der Zeichenfolge in $info Es können Sonderzeichen vorhanden sein die Fehler verursachen. Gibt es also eine Möglichkeit, jede Zeichenfolge von $info zu maskieren?

Kann

nur maskiert werden, wenn $info definiert wird?

Antwortinhalt:

<code>    $info = array(
        "https://segmentfault.com/q/1010000003711515",
        "http://www.baidu.com?admin.php&jasdhjas=asjd",
        'php $a=0; echo "abc";',
        "假如这是第三个....*^%$#@!()[]{}",
        );
    foreach ($info as $key => $value) {
        $message = "https://segmentfault.com/q/1010000003711515";
        $preg = "/^".$value."$/";
        if (preg_match($preg, $message)) {
            echo '匹配成功';
            break;
        }
    }</code>

durchläuft das Array $info, fügt /^ vor und nach jeder Zeichenfolge hinzu und $/ wird zu einem regulären Ausdruck, der mit dem bereitgestellten $message übereinstimmt, aber aufgrund der Zeichenfolge in $info Es können Sonderzeichen vorhanden sein die Fehler verursachen. Gibt es also eine Möglichkeit, jede Zeichenfolge von $info zu maskieren?

Kann

nur maskiert werden, wenn $info definiert wird?

/ hat in regulären Ausdrücken eine besondere Bedeutung, daher führt das folgende „/“ zu einem Fehler. Sie müssen einen Backslash davor einfügen, um es zu maskieren.

$preg ist definiert, aber $info wird verwendet.
Außerdem müssen reguläre Platzhalter mit maskiert werden. Ihr obiges Beispiel sollte als
umgeschrieben werden

<code>$preg = "/^https:\/\/segmentfault\.com\/q\/1010000003711515$/";
    $test = "https://segmentfault.com/q/1010000003711515";
    preg_match($preg, $test);</code>

Ich denke, es ist besser für Sie, einfach zu sagen, was Sie tun möchten. Ich habe das Gefühl, dass Ihre Denkweise falsch ist.

$preg ist eine unbekannte Variable
Ihre Prämisse ist zu groß

Wenn diese Ausdrücke von Programmierern eingegeben wurden, dann ist es das Problem des Programmierers.

Wenn diese Ausdrücke von Benutzern eingegeben werden, dann sollte der Benutzer auf der Eingabeoberfläche darauf hingewiesen werden, dass es sich um reguläre Ausdrücke handelt, damit er darauf achten kann.

Sie können js verwenden, um die Sonderzeichen des regulären Ausdrucks zu maskieren, dies kann jedoch zu doppeltem Escapezeichen führen (z. B. hat der Benutzer ursprünglich den maskierten Inhalt http:|b4831e42daf1db770cdbc01d41578e020|/. eingegeben)

Beispiel

<code>document.getElementById('test').value = (new RegExp(document.getElementById('test').value)).toString();</code>
Außerdem kann es auch zu Problemen kommen, wenn Sie /^ und $/ im Programm gewaltsam hinzufügen.

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