0
イメージをmysqlデータベースにアップロードしようとしていますが、イメージをアップロードするときに確認メッセージが表示されますが、データベースをチェックするとイメージ行が空白になります。イメージをデータベースに挿入
<?php include "connection.php"; ?>
<?php
$n=$_POST["num"];
$t=$_POST["texto"];
$i=$_POST["imagem"];
$image = addslashes(file_get_contents($_FILE['$i']['tmp_name']));
if ($connect->connect_error){
\t die("Connection failed: " . $connect->connect_error);
}
$sql = "UPDATE servicos SET texto='$t', imagem='{$image}' where nmr=$n" ;
if ($connect->query($sql) === TRUE) {
\t echo "informação atualizada";
} else {
\t echo "Error: " . $sql . "<br>" . $connect->error;
}
$connect->close();
?>
<html>
<body>
<div class="formulario" style="width: 100%; height: 100%;">
<form enctype="multipart/form-data" name="form1" target="apresenta" method="post" action="menu2.php" style="position:absolute; top:70;left:10
border:thin; border-style:none;">
<label> Atualizar dados </label><br>
Numero: <input type="text" name="num" value=""><br>
Texto: <input type="text" name="texto" value=""><br>
Imagem: <input type="file" name="imagem" value=""><br>
<input type="submit" name="submit" value="enviar">
<input type="reset" value="limpar">
</form>
</div>
</body>
</html>
なぜaddslashesを使用していますか(file_get_contents(?参照:https://www.w3schools.com/php/php_file_upload.asp –
なぜデータベースサイズを増やしたいのですか?データベースにファイルを保存するにはファイルシステムの助けを借りてください。データベースにファイルを保存したい場合は、まずデータベースをbase64形式またはデータベースに保存できる他の形式に変換する必要があります。 – itzmukeshy7
Aこれを処理する一般的な方法は、イメージをファイルシステムに保存し、データベースへの画像のパスだけを格納することです。 – fredrover