douji2520 2014-02-18 19:30
浏览 23
已采纳

通过php淘汰垃圾邮件发送者/机器人

I am trying to create a hidden email field in my contact form that, when filled out, will not send me an email (meaning a spammer filled in the hidden email field), instead, just sending the spammer to a confirmation page saying that the email was sent.

I can't get it to work properly.

Test site - http://www.webexplosive.com/s1/contact.html

Here is my php script for the contact form:

<?php
    $firstname = $_POST['firstname'];
    $lastname = $_POST['lastname'];
    $email1 = $_POST ['email1'];
    $phone = $_POST ['phone'];
    $comments = $_POST ['comments'];
    $testBot = $_POST ['email2'];

    $headers = "MIME-Version: 1.0
";
    $headers = "From: $email1";
    $to = 'beefjelly69@yahoo.com';
    $subject = 'Contact Form Submitted - Virginia Subsite';
    $message = "
    First name: $firstname 

    Last name: $lastname 

    Email: $email1 

    Phone: $phone 

    Comments: $comments 
";

    mail($to, $subject, $message, $headers);

    header("Location: thankyou.html");

    if(email2 == "") { //If email2 form section is blank then... 
        $firstname = $_POST['firstname'];
        $lastname = $_POST['lastname'];
        $email1 = $_POST ['email1'];
        $phone = $_POST ['phone'];
        $comments = $_POST ['comments'];
        $testBot = $_POST ['email2'];

        $headers = "MIME-Version: 1.0
";
        $headers = "From: $email1";
        $to = 'beefjelly69@yahoo.com';
        $subject = 'Contact Form Submitted - Virginia Subsite';
        $message = "
        First name: $firstname 

        Last name: $lastname 

        Email: $email1 

        Phone: $phone 

        Comments: $comments 
";

        mail($to, $subject, $message, $headers);

        header("Location: thankyou.html");
    }
    else {
        header("Location: thankyou.html");

    }
?>
  • 写回答

5条回答 默认 最新

  • dttl3933 2014-02-18 19:33
    关注

    This is because you always call the mail form first. You need to validate it before you call it. Call the mail function after you have checked that the email2 field is empty.

    As it is, it will always send the mail, before hitting the if statement.

    Suggestion: Look into implementing a captcha or something similar than that.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥66 如何制作支付宝扫码跳转到发红包界面
  • ¥15 pnpm 下载element-plus
  • ¥15 解决编写PyDracula时遇到的问题