任务的目的是使用PhP中的ajax将数据插入到postgresql中,页面不应该刷新,它只是插入数据并向用户显示操作成功的消息。
我遵循Insert Data mysql using Ajax and PHP进行编码,以将数据插入到postgresql数据库中。但是有一些未知的问题。控件甚至都不会转到将输入插入数据库的服务器上的页面。我将客户端和服务器端代码都放在同一个文件夹中,以避免由于路径问题。我的客户端代码是: alta_usuari.php
<!DOCTYPE html>
<html>
<head>
<style> <?php include './../css/alta_usuari.css'; ?> </style>
<script src='http://code.jquery.com/jquery-3.1.1.min.js'></script>
<script>
$(document).ready(function() {
$('#button_alta').click(function(event) {
event.preventDefault();
console.log("about to start AJAX call");
var bracalet = $('#textbox_bracalet').val();
var tag = $('#textbox_tag').val();
$.ajax({
type: "POST",
url: 'pages/alta_usuari_server.php',
data: {
bracalet: bracalet,
tag: tag
},
success: function(data) {
console.log(tag);
console.log(result);
alert(result);
$("#message").html(data);
alert('data has been storeds to database');
}
});
});
});
</script>
</head>
<body>
<div id="mainDiv_alta_usuari">
<form id="form_alta_usuari" class="form_alta_usuari">
<p><input type="text" name="bracalet" id="textbox_bracalet" placeholder="Escaneja el bracalet...." /></p>
<p><input type="text" name="tag" id="textbox_tag" placeholder="Escaneja el tag...." /></p>
<p><input type="submit" id="button_alta" value="Donar d'alta" /></p>
</form>
<div id="message"> </div>
</div>
</body>
</html>
alta_usuari_server.php代码
<html>
<body>
Bracalet: <?php echo $_POST["bracalet"]; ?><br>
Tag: <?php echo $_POST["tag"]; ?>
<?php
header("Content-Type: application/json; charset=UTF-8");
$mac=$POST['tag'];
$bracalet=$POST['bracalet'];
$ini = parse_ini_file('config.ini');
$host=$ini['host'];
$port =$ini['port'];
$user =$ini['user'];
$pass =$ini['password'];
$db = $ini['db'];
$con = pg_connect("host=$host dbname=$db user=$user password=$pass")
or die ("Could not connect to server\n");
$query = "INSERT INTO beacon VALUES($mac)";
$result = pg_execute($con, $query) or die("Cannot execute query: $query\n");
if($result)
{
$data="Insert successfully";
}
else{
$data="Error";
}
echo json_encode($data);
pg_free_result($data);
pg_close($con);
?>
</body>
</html>
最简单的alta_usuari_server.php
<?php
$mac=$_POST['tag'];
$bracalet=$_POST['bracalet'];
echo $mac;
echo $bracalet;
$data="tahir";
echo json_encode($data);
?>
答案 0 :(得分:0)
在alta_usuari_server.php中,您在设置Content-Type标头之前发送了一些标记。这是无效的。您需要确保,如果要设置响应标头,它是脚本的第一个输出。它必须在标记和echo语句之前。