0

我在做什么:
试图减少想要在我的网站上注册的垃圾邮件发送者。

而且我知道:
点在 gmail 中被忽略,您可以在电子邮件地址的本地部分的任何地方放置点,但在 @ 之前的第一个位置和最后一个位置。

问题:
当用户使用 ex.ample@gmail.com 在站点中注册时,一切正常,但是当他可以在站点中再次使用 ex.am.pl.e@gmail.com 等注册时出现问题。

我所做的是:
删除电子邮件本地部分中的任何点,但我意识到用户无法使用他刚刚输入的电子邮件地址提交。

我想要的是:
有没有办法克服这个问题?因为在这种情况下,一个人可以通过更改电子邮件地址中的点位置来注册很多次。

4

1 回答 1

5

我确定您现在已经找到了解决方案,但是为了完整起见...

基本上,您需要按原样存储本地部分,而不去除点,然后在比较时从应用程序和注册表中去除点。喜欢:

$registered_emails[0]="e.xample@gmail.com"; //This is just to show how it was registered first time
$application_email="exam.ple@gmail.com"; //New application email

$discard=0; //flag for discarding application
if (preg_match("/@gmail.com$/i", $application_email)===1) {
   $app_em=str_replace(".", "", $application_email);
   foreach ($registered_emails as $reg_em)
      if ($app_em==str_replace(".", "", $reg_em)) {
      // "example@gmailcom"=="example@gmailcom"
         $discard=1; // discard application
         break;
      }
      //can't use an "else" clause here to break, as you need to loop through all registries
}
if ($discard==1)
   echo "discard application";
else
   array_push($registered_emails, $application_email); //register $application_email as is (exam.ple@gmail.com)

之前可能值得从列表中过滤掉所有 gmail 电子邮件,甚至将所有 gmail 电子邮件存储在一边;当然不是最优雅的解决方案,但可能是最快的解决方案

于 2012-12-06T14:32:48.703 回答