1
当我提交表单时,我可以将文章的信息传递到我的数据库中,但是我的图像的信息不会发送。将图像信息存入数据库时遇到问题
我正在使用一个事务,所以我可以从1个表格中插入信息到2个表格中。
这是将信息传递给数据库的事务:
$conn->query("START TRANSACTION");
$stmt = $conn->prepare('INSERT INTO articles(article_title, article_text, article_date) VALUES (?, ?, NOW())');
$stmt->bind_param('ss', $_POST['article_name'], $_POST['description']);
$stmt->execute();
$stmt = $conn->prepare('INSERT INTO images (article_id, image_caption, image_filename) VALUES(LAST_INSERT_ID(),?,?)');
$stmt->bind_param('ss', $_POST['image_caption'], $_FILES['upload']['name']);
$stmt->execute();
$stmt->close();
$conn->query("COMMIT");
这里是我的形式:
<form id="inputArticle" name="inputArticle" method="post" action="" enctype="multipart/form-data" >
<p> <label for="article_name">Article Title:</label> <input name="article_name" placeholder="Name of the article" id="article_name" type="text" size="50" maxlength="50" /> </p>
<p> <label for="description">Article Content:</label> <textarea name="description" placeholder="Content of the article"id="description" cols="50" rows="10"></textarea> </p>
<p> <label for="image_filename">Choose File to Upload</label><br /> <input type="file" name="image_filename" id="image_filename" /> </p>
<p> <label for="image_caption">Image Caption:</label> <textarea name="image_caption" id="image_caption" cols="50" rows="5"></textarea> </p>
<p> <input type="submit" name="insert" value="Insert New Article" /> </p>
</form>
侧面说明: 当我从删除的图片上传代码SQL和窗体,一切似乎工作。 ID和描述被发送到数据库,所以我认为问题是与图像上传部分。
Issent $ _FILES应该[ '上传'] [ '名']为$ _FILES [ 'IMAGE_FILENAME'] [ '名称''] –
完蛋了!我现在觉得很愚蠢。感谢乔纳斯 –
没问题:)回答你自己的问题,并采取“解决”的标志,请:-) –