2012-07-18 95 views
1

我試圖集成PHP的壞詞過濾 輸入通過$ _REQUEST採取[「qtitle」]和$ _REQUEST [「問題」] 但我沒有這樣做髒話過濾器集成

$USERID = intval($_SESSION['USERID']); 

if ($USERID > 0) 
{ 
$sess_ver = intval($_SESSION[VERIFIED]); 
$verify_asker = intval($config['verify_asker']); 
if($verify_asker == "1" && $sess_ver == "0") 
{ 
    $error = $lang['225']; 
    $theme = "error.tpl"; 
} 
else 
{ 
    $theme = "ask.tpl"; 
    STemplate::assign('qtitle',htmlentities(strip_tags($_REQUEST['qtitle']), ENT_COMPAT, "UTF-8")); 
    STemplate::assign('question',htmlentities(strip_tags($_REQUEST['question']), ENT_COMPAT, "UTF-8")); 
    if($_REQUEST['subform'] != "") 
    { 
     $qtitle = htmlentities(strip_tags($_REQUEST['qtitle']), ENT_COMPAT, "UTF-8"); 
     $question = htmlentities(strip_tags($_REQUEST['question']), ENT_COMPAT, "UTF-8"); 
     $category = intval($_REQUEST['category']); 


     if($qtitle == "") 
     { 
      $error = $lang['3']; 
     } 
     elseif($category <= "0") 
     { 
      $error = $lang['4']; 
     } 
     else 
     { 
      if($config['approve_stories'] == "1") 
      { 
       $addtosql = ", active='0'"; 
      } 
      $query="INSERT INTO posts SET USERID='".mysql_real_escape_string($USERID)."', title='".mysql_real_escape_string($qtitle)."',question='".mysql_real_escape_string($question)."', tags='".mysql_real_escape_string($qtitle)."', category='".mysql_real_escape_string($category)."', time_added='".time()."', date_added='".date("Y-m-d")."' $addtosql"; 
      $result=$conn->execute($query); 
      $userid = mysql_insert_id(); 
      $message = $lang['5']; 
     } 
    } 
} 
} 

else 
{ 
$question = htmlentities(strip_tags($_REQUEST['qtitle']), ENT_COMPAT, "UTF-8"); 
$redirect = base64_encode($thebaseurl."/ask?qtitle=".$question); 
header("Location:$config[baseurl]/login?redirect=$redirect");exit; 
} 

我想下面的代碼,但是這個代碼替換每一個字(不包括在陣列中)

FUNCTION BadWordFilter(&$text, $replace){ 

$bads = ARRAY (
    ARRAY("butt","b***"), 
    ARRAY("poop","p***"), 
    ARRAY("crap","c***") 
); 

    IF($replace==1) {          //we are replacing 
    $remember = $text; 

    FOR($i=0;$i<sizeof($bads);$i++) {    //go through each bad word 
     $text = EREGI_REPLACE($bads[$i][0],$bads[$i][1],$text); //replace it 
    } 

    IF($remember!=$text) RETURN 1;      //if there are any changes, return 1 

} ELSE {             //we are just checking 

    FOR($i=0;$i<sizeof($bads);$i++) {    //go through each bad word 
     IF(EREGI($bads[$i][0],$text)) RETURN 1; //if we find any, return 1 
    }  
} 
} 
$qtitle = BadWordFilter($wordsToFilter,0); 
$qtitle = BadWordFilter($wordsToFilter,1); 

我是缺少在這裏?

+2

*(TIP)*谷歌「clbuttic」。然後放棄努力想出一個字過濾器。 – Gordon 2012-07-18 14:04:10

+0

嗯,我懶得看完整個代碼,但是我在第一眼看到的就是說你最好重寫你的腳本。例如,'eregi'已棄用。順便說一句,爲什麼你使用關鍵字大寫? – Leri 2012-07-18 14:05:39

+1

通常,FULL_CAPS爲常量保留,PascalCase爲類,camelCase爲變量和函數。公約是一個敏感的話題,但是在這裏左右都有公認的規則。 – Dan 2012-07-18 14:06:41

回答

0

我@Gordon同意這是重新發明輪子,但如果你真的想這樣做,這裏有一個更好的開始:

function badWordFilter(&$text, $replace) 
{ 
    $patterns = array(
     '/butt/i', 
     '/poop/i', 
     '/crap/i' 
    ); 

    $replaces = array(
     'b***', 
     'p***', 
     'c***' 
    ); 

    $count = 0; 
    if($replace){ 
     $text = preg_replace($patterns, $replaces, $text, -1, $count); 
    } else { 
     foreach($patterns as $pattern){ 
      $count = preg_match($pattern, $text); 
      if($count > 0){ 
       break; 
      } 
     } 
    } 

    return $count; 
} 

有很多固有的問題,雖然。例如,運行上的文字How do you like my buttons?過濾器...你會擁有How do you like my b***ons?

+0

我可以指定一個替代品,而不是替換爲同一個替代品嗎? – user1528878 2012-07-18 20:08:45

+0

我也可以用.txt文件替換這個ARRAY,這樣我就可以把所有壞字都放到txt文件中 – user1528878 2012-07-18 20:24:49

+0

如果你想用一個字符串替換所有的匹配,你可以把'$ replaces'數組改爲一個字符串:'$ replaces ='****';'...如果你想從文本文件中加載壞詞,你可以,但你必須讓它們進入preg模式,以便它們用' preg_replace' ... – keithhatfield 2012-07-18 20:42:57

0

我認爲你應該使用這種功能:

function badWordsFilter(&$text){ 
    $excluded_words = array('butt', 'poop', 'crap'); 
    $replacements = array(); 

    $i = count($excluded_words); 
    while($i--){ 
     $tmp = $excluded_words{0}; 
     for($i=0;$i<(strlen($excluded_words)-1);$i++){ 
      $tmp .= '*'; 
     } 
     $replacements[] = $tmp; 
    } 

    str_replace($excluded_words, $replacements, $text); 
} 
+0

我該如何調用要替換的單詞的功能? – user1528878 2012-07-18 20:19:47

+0

您應該只傳遞整個字符串,其中一些單詞應該替換爲該函數,並且它完成所有工作:) 爲了添加要審查的單詞,您只需將它們添加到$ excluded_words即可! – PoulsQ 2012-07-18 20:36:37

+0

我可以使用.TXT文件替換數組,以便我可以加載所有不良文字frm此文件? – user1528878 2012-07-19 06:02:24