使用 AJAX 提交时发送电子邮件不起作用

Posted

技术标签:

【中文标题】使用 AJAX 提交时发送电子邮件不起作用【英文标题】:Send email on submit with AJAX is not working 【发布时间】:2021-12-31 23:44:05 【问题描述】:

我想在单击按钮时发送电子邮件。该按钮是使用引导程序 5 创建的。然后 Jquery 将向应发送电子邮件的 php 文件发送 AJAX 请求。但看起来请求的 email.php 文件没有被调用。没有执行该文件中的代码,没有退出。在控制台中,我从 ajax 收到了成功消息,并且“单击了按钮 2”。我检查了几个帖子。怎么了?请看下面的代码。

form.php

            <div class="text-center mt-4 mb-4 ftp-order">
            <button type="submit" name="ftp-submit" id="ftp-submit" class="btn btn-success"><?php echo $arr_lang['bestellen']; ?></button>
        </div>

main.js

    $('#ftp-submit').click(function (e) 
    e.preventDefault();
    console.log("Button clicked");
        $.ajax(
            url: 'dateien/ajax/premium_account.php',
            data: 'pressed:pressed',
            datatype: 'JSON',
            type: "POST",
            success: function (data) 
                console.log("Button clicked 2");
            ,
            error: function (error) 
                alert('There was some error');
                console.log(error);
            ,
        );
    $('#ftp-alert').css("display", "block");
    return false;
);

电子邮件.php

    $sender = "sender@example.com";

if(mail('info@example.com', 'FTP', 'Test', $sender)) 
    echo 'sent mail';
    exit('exit1');
 else 
    echo 'error sending email';
    exit('exit2');


if (isset($_POST)) 
    exit('exit');
    ?>
    <script>console.log("received")</script>
<?php


?>

<div id="test"></div>
<script>console.log("received")</script>

【问题讨论】:

尝试将data: 'pressed:pressed', 更改为data: pressed: 'pressed',。如果引用对象,则将其作为字符串发送,而不是作为 post 参数发送。 使用 if($_SERVER["REQUEST_METHOD"] === "POST") //Your email code goes here 这将确保只接受 POST 请求,而 data: 'pressed:pressed' data: pressed: 'pressed' 另外,exit() 会立即终止脚本的执行,因此如果您之后有任何echo(或任何代码),它将不会被执行。你的if (isset($_POST)) 也永远不会被执行,因为你有和if/else 两个状态都包含exit 您还应该read the manual 为mail() 了解如何正确添加发件人地址。 您的 AJAX 调用 dateien/ajax/premium_account.php 而您显示 email.php,它们之间有什么关系?此外,如果您实际上没有提交表单,您可以将按钮更改为“常规”按钮(type="button" 而不是type="submit")并删除e.preventDefault(); 【参考方案1】:

尝试检查您的邮件服务器,它必须正确配置才能使 mail() 函数可用。

【讨论】:

以上是关于使用 AJAX 提交时发送电子邮件不起作用的主要内容,如果未能解决你的问题,请参考以下文章

表单验证在使用 ajax 方法提交之前不起作用

使用 jquery 发送电子邮件不起作用:PHP

如何在 AJAX 中发布数据?

SMTP 配置在生产中不起作用

使用 PHP 和 AJAX 发送电子邮件表单

使用 wp_mail() 发送 HTML 电子邮件时,CSS 将不起作用