jQuery $ .post()执行两次之后的php代码

时间:2013-05-07 14:23:08

标签: php ajax execution

我还是PHP和AJAX的新手,但我想我对JavaScript和jQuery有一些把握。这是我的问题:在我的UI中,我有一个表单输入字段和一个OK按钮(它不是表单的一部分)。每次用户单击ok按钮时,输入字段的内容加上一些会话变量都应通过AJAX发送到服务器,这样页面就不必重新加载。

这是我的js-Code:

$.post('api/someFile.php',
  {
    var1: nr1,
    var2: nr3,
    var3: nr3,
  }
);

这是我的php代码someFile.php

<?php
  // activate current session
  session_start();

  // use php console for debugging    
  require_once('PhpConsole.php');
  PhpConsole::start();

  // get data from UI
  $var1 = $_POST["var1"];
  $var2 = $_POST["var2"];
  $var3 = $_POST["var3"];

  debug("start receiving");
  debug($var1 . " " . $var2 . " " . $var3);

  // ... proceed with the data and write it in database...

  debug("finished");
?>

问题是someFile.php中的所有代码都执行了两次。这是控制台输出:

javascript debug: send to server: nr1, nr2, nr3
php debug: start receiving
php debug: nr1 nr2 nr3
php debug: finished
php debug: start receiving
php debug: nr1 nr2 nr3
php debug: finished

但是,数据只在数据库中写入一次。这很奇怪。这是php控制台中的错误还是我的代码不好?

1 个答案:

答案 0 :(得分:1)

它的发生是因为HTTP OPTIONS首先执行,并且您在执行逻辑之前限制了不需要的HTTP方法,请始终使用isset方法,请参阅下面的示例

if(isset($_POST))
 {
    $name = $_POST["name"];
    $country = $_POST["country"];

    $sql = 'INSERT INTO user values("' . $name . '","' . $country . '")';

            if ( $conn->query($sql)=== TRUE) 
            {
                $outp =  "Inserted " .  $name . "  and  "  . $country;
                echo json_encode($outp);
            } else {
                echo json_encode("Error: " . $sql . "<br>" . $conn->error);
            }
        }

这里只有在POST POST时才会在表中插入行。