我还是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控制台中的错误还是我的代码不好?
答案 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时才会在表中插入行。