<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?
nur maskiert werden, wenn $info
definiert wird?
<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?
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>