我创建了一个数据库,用于存储有关图像以及图像本身的各种数据。我有五把钥匙(id, name, size, format, file)。是id自动递增的。是fileBLOB 类型的值 - (mediumblob)。休息有其各自的类型。奇怪的是,除了 BLOB 图像本身之外,所有其他变量都已成功写入数据库。
等待用户使用以下命令上传图像$_POST:
if(isset($_POST['file_one_submit'])){
$post = 'file_one_input';
}
Run Code Online (Sandbox Code Playgroud)
定义所有变量。包括$file变量:
$file = file_get_contents($_FILES[$post]['tmp_name']);
Run Code Online (Sandbox Code Playgroud)
然后我进行查询以用新信息替换数据库中的记录:
$stmt = $conn -> prepare("REPLACE INTO `images` (id, name, size, format, file) VALUES(?, ?, ?, ?, ?);");
$stmt -> bind_param("isisb", $id, $name, $size, $format, $file);
$stmt -> execute();
Run Code Online (Sandbox Code Playgroud)
file执行查询后,数据库中的所有记录都会成功更新,但应包含 BLOB 数据的列除外。我认为该$post变量可能定义不正确,但获取上传文件的名称例如可以:
upload_name = $_FILES[$post]['name'];
Run Code Online (Sandbox Code Playgroud)
我尝试回显该$file变量以检查其内容,但收到了一大堆垃圾数据,我认为这些数据是在使用该file_get_contents()函数转换为 BLOB 期间生成的正确字符串。
我已经检查过文件的大小没有超出mediumblobBLOB 类型的容量。 …