使用 jQuery ajax post 接收 PHP 参数

Posted

技术标签:

【中文标题】使用 jQuery ajax post 接收 PHP 参数【英文标题】:Receive PHP parameters with jQuery ajax post 【发布时间】:2012-08-02 22:09:02 【问题描述】:

我通过 jQuery 的 .ajax 方法将数据发送到我的 php 文件。两个文件都在同一个域中。发帖的文件是这样的..

$('#pdf').click(function()                     
    var proj_name = $('#proj_name').text();
    var date = $('#date').text();
    var req_comp_date = $('#req_comp_date').text();
    var status = $('#status').text();
    var secondUserID = $('#secondUserID').text();

    var postData = 
        "proj_name" : proj_name,
        "date" : date,
        "req_comp_date" : req_comp_date,
        "status" : status,
        "secondUserID" : secondUserID,
    ;

    console.log(postData);

    $.ajax(
        type: "POST",
        url: "test.php",
        data: postData, 
        success: function()
            alert(proj_name + ' ' + status);
            window.open("test.php"); 
        
    );
);

获取post数据的PHP文件是……

//request parameters
$proj_name = $_POST['proj_name'];
$date = $_POST['date'];
$req_comp_date = $_POST['req_comp_date'];
$status = $_POST['status'];
$secondUserId = $_POST['secondUserId'];

echo 'postData: ' . var_dump($_POST);

if ($_POST))
    echo $proj_name;
    echo $date;
    echo $req_comp_date;
    echo $status;
    echo $secondUserId;
 else 
    echo 'problem';

在我的 firebug 控制台中,我可以看到使用 .ajax 发布的参数,但我无法通过 PHP 获取该帖子。谁能帮帮我?谢谢。

【问题讨论】:

所以假设你的 $.post() 中的 url 是正确的,做 var_dump( $_POST );在您的 php 文件的顶部。你得到了什么?如果那里没有任何内容,请验证您发送到正确的网址。 【参考方案1】:

如果请求失败,请将错误回调添加到您的 $.ajax 调用以进行调试。

$.ajax(
    type: "POST",
    url: "test.php",
    data: postData, 
    success: function()
        alert(proj_name + ' ' + status);
        window.open("test.php"); 
    ,
    // Alert status code and error if fail
    error: function (xhr, ajaxOptions, thrownError)
        alert(xhr.status);
        alert(thrownError);
    
);


更新

改变这个:

if ($_POST))
    echo $proj_name;
    echo $date;
    echo $req_comp_date;
    echo $status;
    echo $secondUserId;
 else 
    echo 'problem';

到这里:

if ($_POST))
    // Make a array with the values
    $vals = array(
        'proj_name'     => $proj_name,
        'date'          => $date,
        'req_comp_date' => $req_comp_date,
        'status'        => $status,      
        'secondUserId'  => $secondUserid
    );

    // Now we want to JSON encode these values to send them to $.ajax success.
    echo json_encode($vals);

    exit; // to make sure you arn't getting nothing else

 else 
    // so you can access the error message in jQuery
    echo json_encode(array('errror' => TRUE, 'message' => 'a problem occured'));
    exit;

现在在你的 jQuery .success 回调中:

success: function(data) // Our returned data from PHP is stored in "data" as a JSON Object
    alert(data.req_comp_date); // access your returned vars like this.
    // data.date; // is your posted date.. etc
    alert(data.proj_name + ' ' + data.status);
    window.open("test.php"); 

    // You can also get your error message like so..
    if(data.error) // if its true, we have a error, so display it.
         alert('ERROR: ' + data.message); 

,

您实际上不必再执行此操作(jquery 可以很好地确定返回的数据类型),但很高兴在代码中包含它以了解返回的内容。

$.ajax( ...
    type: "POST",
    url: "test.php",
    data: postData, 
    dataType: "json" // <-- Add this to tell jquery, we are being returned a JSON object.
.... );

【讨论】:

感谢您的帮助。我没有得到错误捕捉工作。我确实看到了我对 PHP 文件的萤火虫响应。数组([proj_name] => 项目名称:8.3 PRDx 未保存草稿 [date] => 日期:2012-08-03 [req_comp_date] => 请求完成日期:n/a [status] => 状态:等待 [secondUserID] => 分配另一个用户来编辑这个项目请求文档? Nilo Zaratan )所以,我只需要以某种方式将它输出到页面。它没有正确回显。

以上是关于使用 jQuery ajax post 接收 PHP 参数的主要内容,如果未能解决你的问题,请参考以下文章

JQuery AJAX Webmethod POST 接收对象

我用的是thinkphp3.2.3为啥使用jquery的ajax接收不到post值

jQuery中的AJAX

现需要使用 jQuery 代码实现 ajax 请求,详细信息如下

Jquery中post方法传值,php内无法接收到,请求各位帮助,多谢

jquery封装好的ajax方法