2011-10-18 86 views
0

经过2次尝试(感谢堆栈溢出)后,我终于得到了我的正则表达式url,并按照我的意愿以不同的方式将特定的事情列入黑名单。然而,它不能正常工作,而是的;它列入黑名单的话,并防止它们被输入到数据库中,它抛出了一个错误:preg_match()语句中的未知修饰符

PHP Warning: preg_match() [function.preg-match]: Unknown modifier '\\' in C:\wamp\www\anonpost\index.php on line 324, referer: http://localhost/anonpost/index.php

这里是我的代码:

$disallowedWords1 = array(
'offensive','words' 
); 

foreach ($disallowedWords1 as $word1) { 
    if (preg_match("/\b$word1\b/i", $entry)) { 
    die('The word or phrase ' . $word . ' is not allowed...'); 
    } 
} 

$urlRegex = '(http|https|ftp)\://([a-zA-Z0-9\.\-]+(\:[a-zA-Z0-9\.&%\$\-]+)*@)*((25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9])\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[1-9]|0)\.(25[0-5]|2[0-4][0-9]|[0-1]{1}[0-9]{2}|[1-9]{1}[0-9]{1}|[0-9])|localhost|([a-zA-Z0-9\-]+\.)*[a-zA-Z0-9\-]+\.(com|edu|gov|int|mil|net|org|biz|arpa|info|name|pro|aero|coop|museum|[a-zA-Z]{2}))(\:[0-9]+)*(/($|[a-zA-Z0-9\.\,\?\'\\\+&%\$#\=~_\-]+))*'; 
if (preg_match($urlRegex, $entry)) { 
    die('The word or phrase ' . $word . ' is not allowed...'); 

} 

我看了一些帖子说是在网站上类似,他们都非常明确地指出,没有分隔符,我也有这些,所以我真的失去了它的可能性。任何帮助将不胜感激:)

(对于错误的一个例子,其中有三个[三个不同的preg_match()语句,每个只有勉强不同,主要是它发现文本的方式]尝试发布,它不是一个问题,它只是使它看起来凌乱:在正则表达式http://aviatex14.co.uk/anonpost/

+0

见http://php.net/manual/en/regexp.reference.delimiters.php和可能也'preg_quote'。 – mario

回答

1

逃避所有的/或使用另一个章节前分隔符,即~#

if (preg_match("#$urlRegex#", $entry)) { 

而且您正则表达式可以缩短:

$urlRegex = "(https?|ftp)://([a-zA-Z0-9.-]+(:[a-zA-Z0-9.&;%$-]+)*@)*((?:(25[0-5]|2[0-4]\d|[01]\d{2}|[1-9]\d|[1-9])\.){3}(25[0-5]|2[0-4]\d|[01]\d{2}|[1-9]\d|[1-9]|0)|localhost|([a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]+\.(com|edu|gov|int|mil|net|org|biz|arpa|info|name|pro|aero|coop|museum|[a-zA-Z]{2}))(:\d+)*(($|[a-zA-Z0-9.,?'+\\&;%\$#=~_-]+))*"; 
-1

使用#标签,即:

preg_match("#/\b$word1\b/i#", $entry) 

(您可能需要删除开始斜杠)

相关问题