gpt4 book ai didi

jquery - 无法将数据从表单发送到 SQL 数据库

转载 作者:太空宇宙 更新时间:2023-11-03 10:31:45 25 4
gpt4 key购买 nike

所以我有这段代码,它接受用户输入到表单中,并在单击提交时更新 SQL 数据库(不刷新页面)。问题是它没有将值更新/发送到 sql 表。

我已尝试按照我在多个站点上找到的示例和教程进行操作,但我无法使它们中的任何一个起作用。

我有用于数据库连接和更新的表单 (index.html) 和 php 文件 (upd.php)。它的代码如下。

我正在尝试将这些值保存到数据库中 名为 messages 的表:-

  • timestamp(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,当我点击提交时,它仍然显示已提交,但表中没有任何更新

最佳答案

您的代码存在多个问题。查看有关 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>

问候

关于jquery - 无法将数据从表单发送到 SQL 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56786652/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com