使用从ajax请求中检索的数据发送电子邮件

时间:2015-11-19 20:18:34

标签: javascript php jquery ajax email

我正在尝试通过点击按钮从文本字段中检索信息并将数据发送到mail@example.com:

aggregate(text~name, df, FUN= paste, collapse=' ') 

$(document).ready(function() { $("#submit").click(function() { var email = $("#email").val(); var name = $("#Name").val(); var subject = $("#Subject").val(); var text = $("#textarea").val(); var telephone = $("#tel").val(); var varData = "email : " + email + "name : " + name + "subject : " + subject + "text : " + text + "telephone : " + telephone; console.log(varData); $.ajax({ type: "POST", url: 'sendPHP.php', data: varData, success: function() { alert("message sent"); } }); }); });

sendPHP.php

1 个答案:

答案 0 :(得分:2)

虽然目前还不清楚您的确切关注点,但我对您的流程有一些想法。

1 - 您正在将数据作为字符串发送到php文件,这是不推荐的,并且可能会在那里给您带来问题。我真的看到了通过post将数据发送到服务器的两种方法:A)将数据存储在表单中并使用jQuery的$()。serialize()函数,或者B)将数据存储在JSON对象中发送它。

选项B是我首选的方法,因为JSON简化了一切。它的优点是您的数据已经存储为键/值对,而PHP使用json_decode函数可以非常轻松地使用JSON。让我们对您现有的代码进行一些更改:

$(document).ready(function() {
$("#submit").click(function() {
    var email = $("#email").val();
    var name = $("#Name").val();
    var subject = $("#Subject").val();
    var text = $("#textarea").val();
    var telephone = $("#tel").val();
    var varData = {
                     "email"      : email , 
                     "name"       : name, 
                     "subject"    : subject, 
                     "text"       : text ,
                     "telephone"  : telephone
                   } //This is your data in JSON form

    console.log(varData);

    $.ajax({
        type: "POST",
        url: 'sendPHP.php',
        data: JSON.stringifiy(varData), //Notice that I added JSON.stringify
        success: function() {
            alert("message sent");
        }
    });
});

});

现在我将向您展示如何在PHP中处理它 - 它实际上非常简单。

第1步 - 将此JSON对象转换为关联数组,以便于使用:

$input = json_decode(file_get_contents('php://input'), true);

现在我们有一个名为$ input的变量,它是一个包含所有邮件数据的关联数组 - 让我们设置你需要的变量。

$email      = $input['email']; //Notice string in brackets is JSON key
$name       = $input['name'];
$subject    = $input['subject'];
$text       = $input['text'];
$telephone  = $input['telephone'];

好的,很酷 - 您从前端收集的所有数据现在都可以在后端使用了。所以看起来你正在使用PHP提供的内置mail()函数。我强烈建议使用一个库,因为它们通常更加可靠和冗长。我最喜欢的是PHPMailer - 这里是他们的github页面https://github.com/PHPMailer/PHPMailer的链接。

如果您想使用该库,过程很简单。

首先,在脚本中包含自动加载器文件

<?php
    require('PHPMailer-master/PHPMailerAutoload.php');

接下来,他们在许多示例中都记录了这一点,您创建了一个PHPMailer的新实例并设置了一些基本变量 - 这直接来自他们的文档,我保证您会比尝试PHP时更少头痛。 mail()方法https://github.com/PHPMailer/PHPMailer/blob/master/examples/gmail.phps

祝你好运,如果我对任何事情都不清楚,请告诉我。