Вставьте данные в базу данных postgresql, используя ajax и php - PullRequest
0 голосов
/ 20 сентября 2018

Цель задачи - вставить данные в postgresql, используя ajax в PhP. Страница не должна обновляться. Она просто вставляет данные и отображает сообщение пользователю, что операция прошла успешно.

Я следовал Вставьте Data MySQL, используя Ajax и 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);
?>

1 Ответ

0 голосов
/ 25 марта 2019

В alta_usuari_server.php вы отправляете некоторую разметку перед установкой заголовка Content-Type.Это не верноВы должны убедиться, что если вы устанавливаете заголовок ответа, это первый вывод вашего скрипта.Это должно быть до разметки и эхо-операторов.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...