使用 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 提交时发送电子邮件不起作用的主要内容,如果未能解决你的问题,请参考以下文章