小编541*_*35d的帖子

BLOB数据写入数据库失败

我创建了一个数据库,用于存储有关图像以及图像本身的各种数据。我有五把钥匙(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 类型的容量。 …

php mysql mysqli blob

4
推荐指数
1
解决办法
1089
查看次数

标签 统计

blob ×1

mysql ×1

mysqli ×1

php ×1