这个问题之前已经被问过关于字符串的问题,但是*我没有回答过的问题(不是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,仍然没有快乐。
答案 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";
}