因此,我正在尝试创建一个将图像,说明和日期上传到数据库的表单。一切正常,但是无论我尝试什么,日期都保留在注册人上,有什么想法吗?我大部分时间都在学习教程,但是它没有添加日期,所以我想添加日期,因为稍后我希望能够在提交日期之前调用这些条目。
<?php require('check.php');
require_once('settings.php');
include('header.php');
// Create database connection
$db = mysqli_connect("localhost", "-----", "-----", "----");
// Initialize message variable
$msg = "";
// If upload button is clicked ...
if (isset($_POST['upload'])) {
// Get image name
$image = $_FILES['image']['name'];
// Get text
$image_text = mysqli_real_escape_string($db, $_POST['image_text']);
// Get Date
$sermon_date = mysqli_real_escape_string($db, $_POST['sermon_date']);
// image file directory
$target = "images/sermons/".basename($image);
$sql = "INSERT INTO images (image, image_text, sermon_date) VALUES ('$image', '$image_text', '$sermon_date')";
// execute query
mysqli_query($db, $sql);
if (move_uploaded_file($_FILES['image']['tmp_name'], $target)) {
$msg = "Image uploaded successfully";
}else{
$msg = "Failed to upload image";
}
}
if (file_exists($target_file)) {
echo "Sorry, file already exists.";
$uploadOk = 0;
}
$result = mysqli_query($db, "SELECT * FROM images");
?>
<h1>Update Sermon Series</h1>
<form method="POST" action="success.php" enctype="multipart/form-data">
<input type="hidden" name="size" value="1000000">
Sermon Graphic <br />
<input type="file" name="image"><br /><br />
<textarea
id="text"
cols="40"
rows="4"
name="image_text"
placeholder="Describe Sermon"></textarea><br />
Beginning Date of Sermon:<br />
<input type="date" name="sermon_date">
<button type="submit" name="upload">POST</button>
</form>
</body>
</html>
这是我创建表格的地方
$connect = new MySQLi($db_server, $db_user, $db_password, $db_database);
if ($connect->connect_error) {
die("Connection failed: " . $connect->connect_error);
}
$sql = "CREATE TABLE images (
id INT(11) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
image VARCHAR(100) NOT NULL,
image_text LONGTEXT NOT NULL,
sermon_date DATE NOT NULL
)";
if ($connect->query($sql) === TRUE) {
echo "Table created successfully";
} else {
echo "Error creating table:" . $connect ->error;
}
答案 0 :(得分:0)
日期需要以YYYY-MM-DD
格式保存到数据库中,HTML中的日期字段应该已经在这样做了。
如果您的输入未以这种格式发送日期(无论出于何种原因),则可以使用PHP将其转换为这种格式。以下代码采用发布日期并将其转换为以上格式(在PHP中,它转换为Y-m-d
)。
// add this above the insert query
$sermon_date = date('Y-m-d', strtotime($sermon_date));
请注意,如果您接受的日期不是PHP可以检测到的标准格式,那么strtotime
可能无法正常工作。