Невозможно отправить данные из формы в базу данных SQL - PullRequest
0 голосов
/ 27 июня 2019

Итак, Ive этот код, который принимает входные данные от пользователя в форму и обновляет базу данных SQL при нажатии кнопки «Отправить» (без обновления страницы). Проблема в том, что он не обновляет / не отправляет значения в таблицу sql.

Я пытался следовать примерам и учебникам, которые я нашел на нескольких сайтах, но я не могу заставить их работать.

У меня есть форма (index.html) и файл php (upd.php) для подключения и обновления БД. Код для этого ниже.

Я пытаюсь сохранить эти значения в базе данных таблица с именем messages: -

  • метка времени (tstamp): Это динамическое значение, которое является меткой времени видеофайла, воспроизводимого в браузере (например, 1.935771) ,
  • сообщение (любые комментарии)
  • значения флажков

index.html

<body>
  <h1>VIDO LABELLING TOOL</h1>

  <video id="my_video_1" class="video-js vjs-default-skin" controls preload="auto" width="640" height="268"
  data-setup='{ "playbackRates": [0.5, 1, 1.5, 2, 4] }'>
    <source src="project.m4v" type='video/mp4'>
    <track src='br.srt' kind="subtitles" srclang="en" label="English" default>
  </video>



<script>
// Get the audio element with id="my_video_1"
var aud = document.getElementById("my_video_1");

// Assign an ontimeupdate event to the audio element, and execute a function if the current playback position has changed
aud.ontimeupdate = function() {myFunction()};


</script> 


<div class="container" style="max-width:800px;margin:0 auto;margin-top:50px;">
    <form name="contact-form" action="" method="post" id="contact-form">
        <label for="email">Comments about the frame</label>
        <textarea name="message" class="form-control" id="message"></textarea>

        <div class="error" id="error_message"></div>

        <label>Vehicle Type:</label>
        <input name="veh_type_1"  id="veh_type_1" type="checkbox" value="lmv">lmv
        <input  name="veh_type_2" id="veh_type_2" type="checkbox" value="2w">2w
        <p>TimeStamp: <span id="tstamp"></span></p>
  </div>
  <p class="submit">
    <button type="submit" class="btn btn-primary" name="submit" value="Submit" id="submit_form">Submit</button>
  </p>

   <div class="display-content">
    <div class="message-wrap dn">  </div>
   </div>
   </form>
</div>


<script>
    function myFunction() {
        document.getElementById("tstamp").innerHTML = aud.currentTime;
    }
</script>


<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script type="text/javascript">
    $(function() {
        $("#contact-form").on("submit",function(e) {
            e.preventDefault();
            $.ajax({
                type: 'post',
                url: "insert.php",
                data: $( this ).serialize(),
                success: function() {
                    alert("form was submitted");
                }
            });
            return false;
        });
    });
</script>
</body>

Файл php выглядит следующим образом: -

<?php
$servername = "localhost";
$database = "test";
$username = "root";
$password = "";

// Create connection

$conn = mysqli_connect($servername, $username, $password, $database);

// Check connection

if (!$conn) {
      die("Connection failed: " . mysqli_connect_error());
}

echo "Connected successfully";


if(isset($_POST['Submit'])) {
    $tstamp=addslashes($_POST['tstamp']);
    $message=addslashes($_POST['message']);
    $veh_type_1=addslashes($_POST['veh_type_1']);
    $veh_type_2=addslashes($_POST['veh_type_2']);


    mysqli_query($conn, "insert into messages(message,tstamp,veh_type_1, veh_type_2) values ('$message','$tstamp','$veh_type_1', '$veh_type_2')");
    $sql = mysqli_query($conn, "SELECT message,tstamp,veh_type_1,veh_type_2  id FROM messages order by id desc");

    $result = mysqli_fetch_array($sql);
    echo '<div class="message-wrap">' . $result['message'] . '</div>';
}
?>

Структура таблицы следующая: -

 #database=test, table_name=messages
1   idPrimary   int(11)             No  None        AUTO_INCREMENT      
2   message     text        latin1_swedish_ci       Yes     NULL                
3   tstamp      float           No  None            
4   veh_type_1  varchar(5)  latin1_swedish_ci       No  None            
5   veh_type_2  varchar(5)  latin1_swedish_ci       No  None            

РЕДАКТИРОВАТЬ: добавлен код ajax в index.html, все еще, когда я нажимаю кнопку отправить, он говорит, что отправлено, но ничего не обновляется в таблице

Ответы [ 3 ]

2 голосов
/ 27 июня 2019

Есть несколько проблем с вашим кодом. Ознакомьтесь с основами обработки php-форм.

https://www.w3schools.com/php/php_forms.asp

  1. Добавить тэг формы вокруг ввода
  2. Присвойте атрибуты имени вашим входам
  3. Добавить атрибут типа (отправить) к кнопке сохранения
<form action="[path_to_your.php]" method="post">
  <input type="[input type]" name="[name to submit]" >
  ...
  <input type="submit">
</form>

привет

2 голосов
/ 27 июня 2019

Все ваши поля ввода должны иметь имена, чтобы $("form").serialize() мог получить их значения. Так

<input id="veh_type_1" type="checkbox" value="lmv">lmv
<input id="veh_type_2" type="checkbox" value="2w">2w

должно быть

<input name="veh_type_1" type="checkbox" value="lmv">lmv
<input name="veh_type_2" type="checkbox" value="2w">2w

.serialize() также не будет публиковать содержимое <span>, для этого следует добавить скрытый ввод.

<input name="tstamp" id="hidden-tstamp" type="hidden">

и измените свою функцию на:

function myFunction() {
    $("#tstamp").text(aud.currentTime);
    $("#hidden-tstamp").val(aud.currentTime);
}
0 голосов
/ 27 июня 2019
<body>
<h1>VIDEO TOOL</h1>

<video id="my_video_1" class="video-js vjs-default-skin" controls preload="auto" width="640" height="268"
       data-setup='{ "playbackRates": [0.5, 1, 1.5, 2, 4] }'>
    <source src="project.m4v" type='video/mp4'>
    <track src='br.srt' kind="subtitles" srclang="en" label="English" default>
</video>
<script>
    // Get the audio element with id="my_video_1"
    var aud = document.getElementById("my_video_1");
    // Assign an ontimeupdate event to the audio element, and execute a function if the current playback position has changed
    aud.ontimeupdate = function() {myFunction()};
</script>
<div class="container" style="max-width:800px;margin:0 auto;margin-top:50px;">
    <form name="contact-form" action="" method="post" id="contact-form">
        <label for="email">Comments about the frame</label>
        <textarea name="message" class="form-control" id="message"></textarea>

        <div class="error" id="error_message"></div>

        <label>Vehicle Type:</label>
        <input name="veh_type_1"  id="veh_type_1" type="checkbox" value="lmv">lmv
        <input  name="veh_type_2" id="veh_type_2" type="checkbox" value="2w">2w
        <p>TimeStamp: <span id="tstamp"></span></p>
</div>
<p class="submit">
    <button type="submit" class="btn btn-primary" name="submit" value="Submit" id="submit_form">Submit</button>
</p>

<div class="display-content">
    <div class="message-wrap dn">  </div>
</div>
</form>
</div>


<script>
    function myFunction() {
        document.getElementById("tstamp").innerHTML = aud.currentTime;
    }
</script>


<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script type="text/javascript">
    $(function() {
        $("#contact-form").on("submit",function(e) {
            e.preventDefault();
            $.ajax({
                type: 'post',
                url: "saveFile.php",
                data: $( this ).serialize(),
                success: function() {
                    alert("form was submitted");
                }
            });
            return false;
        });
    });
</script>
</body>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...