jquery ajax总会导致错误'即使它有效

时间:2014-06-09 15:41:46

标签: javascript jquery ajax

我有以下JQuery ajax函数,用于更新PHP Session变量。 我发布两个变量,PHP页面收集这些变量并设置相关的Session变量。

偶尔虽然它不起作用,但即使正确的值正在发布。 所以我开始通过向ajax添加成功/错误函数来查看Ajax是否在这些情况下完成了OK。 但我发现,每次我都会得到错误函数的响应,而不是成功函数,即使它成功完成并更新了PHP变量。

我在这里遗漏了什么。我需要创建响应还是应该自动生成?

我的Javascript是:

GBD.updateFunction = function(p,x)
{
    $.ajax(
        {
            type: "POST",
            url: "SetSession.php",
            dataType:'text',
            data: 
                {
                    item:p,
                    section:x
                },
            success: function()
                {
                    alert('success');
                },
            error: function()
                {
                    alert('failure');
                }
            });

         console.log(p + " " + x + " selected");

    return false;
}

setSession。 php是:     

$section = (isset($_POST['section']) ? $_POST['section'] : 0 );

if($section == 1)
{
    if(isset($_POST['item']))
        {
            $pageVar = $_POST['item'];
            $_SESSION['pagevar'] = $pageVar;    
        }
    else
        {
            $_SESSION['pagevar'] = $_SESSION['pagevar'];
        };
}
?>  

1 个答案:

答案 0 :(得分:1)

试试这种方式

//server code
$section = (isset($_POST['section']) ? $_POST['section'] : 0 );
if($section == 1)
 {
  if(isset($_POST['item']))
    {
        $pageVar = $_POST['item'];
        $_SESSION['pagevar'] = $pageVar;    
    }
  else
    {
        $_SESSION['pagevar'] = $_SESSION['pagevar'];

    };
  echo "success";
 }
 ?> 

 //ajax call
 GBD.updateFunction = function(p,x)
{
 $.ajax(
    {
        type: "POST",
        url: "SetSession.php",
        dataType:'text',
        data: 
            {
                item:p,
                section:x
            },
        success: function(data)
            {
                console.log(data);
            },
        error: function(jqxhr)
            {
                //it  will be errors: 324, 500, 404 or anythings else
                console.lgo(jqxhr.responseText); 

            }
        });


    return false;
}