检查数组元素是否在字符串中

时间:2015-09-11 11:18:17

标签: php arrays string strpos stripos

这个问题之前已经被问过关于字符串的问题,但是*我没有回答过的问题(不是mods不会删除或告诉我们这是重复的)请实际回答我的问题。

我有一个登陆页面,通过电子邮箱简单注册。最近人们通过输入*,#,$,%之类的外国字符以及故意使用亵渎(你总能说出来)来滥用它。我有一系列被禁止的字符和我正在使用的单词如下

$banned = array("f**k", "f******", "blah", "*", "#", "$", "%");

我可以肯定地说,有人故意一次又一次地试图通过它,因为我错过了一些角色,突然发现一堆地址根本没有任何意义。我需要知道如何使用For循环来查找以下内容是否包含数组中的任何禁止的单词

$email = $_POST['email'];

我尝试过使用

$arrlen = count($banned);
for($i=0; $i < $arrlen; $i++) {
    if(stripos($email, $banned[$i] !== false) {
        echo 'Banned word or character!';
    }
    else {
        echo 'Email signed up!';
    }
}

这根本不起作用!我尝试了一个旧函数is_str_contain但是函数的错误不存在了。

我也试过了正常的strpos,仍然没有快乐。

5 个答案:

答案 0 :(得分:2)

我一直在修改这个想法,因为我没有现成的代码来帮忙。

以下作品:

$banned = array("badword1", "badword2", "blah", "*", "#", "$", "%");
$_POST['email'] = "emailbadword1@example.com";
$email = $_POST['email'];

    foreach ($banned as $ban) {
        if (stripos($email, $ban) !== FALSE) {
            echo "Match found."; 
            return true;
        }
    }
    echo "No match found.";
    return false;

另外,正如我在评论中提到的那样;你应该使用通过电子邮件发送的确认方法,如果你还没有这样做的话。如果该人未确认其电子邮件地址,则 “停止按下”。

答案 1 :(得分:0)

试试这个

$banned = array("****", "*******", "blah", "*", "#", "$", "%");

$email = $_POST['email'];
foreach ($email as $em) {
    //if (strstr($em, $banned)) { // mine version
    if (strpos($em, $banned) !== FALSE) { // Yoshi version
        echo "Match found"; 
        return true;
    }
}
echo "Not found!";
return false;

答案 2 :(得分:0)

您需要遍历每个被禁止的单词,并查看您的电子邮件是否包含任何被禁止的单词/字符。

$banned = array("****", "*******", "blah", "*", "#", "$", "%");
$email = $_POST['email'];
$banned = false;
for($i=0; $i < count($banned); $i++) {
    if(strrpos($email, $banned[$i]) != FALSE ) {
       $banned = true;
       break;
    }
}
echo $banned ? 'Banned word or character!' : 'Email signed up!'

答案 3 :(得分:0)

您可以将stripos用作

foreach ($banned as $v) {
    if (stripos($email,$v) > -1){
        echo 'Banned word or character!';
    }else{
        echo 'Email signed up!';
    }
}

答案 4 :(得分:0)

使用正则表达式?

if( !preg_match( '/(\b' . implode( '\b|\b', $banned ) . '\b)/i',
 $_POST['email'] )) {
     echo "Match found"; 
}