binary file content shown in php print_r but not saved in mysql(php print_r 中显示的二进制文件内容但未保存在 mysql 中)
问题描述
我必须将输入字段中的文件保存到数据库中,我会这样做:
i have to save the files from input fields to database,i'll do it this way:
$mkey = mysqli_insert_id($mysqli);
$i=0;
while (isset($_FILES['file'.$i])) {
$filepath = ini_get('upload_tmp_dir')."/".basename($_FILES['file'.$i]['tmp_name']);
$filepath = addslashes($filepath);
$handle = fopen($filepath, "rb");
$content = fread($handle, filesize($filepath));
$stmt = $mysqli->prepare("INSERT INTO attachment (filename,filecontent,mkey) VALUES (?,?,?)");
$stmt->bind_param("sbi",$_FILES['file'.$i]['name'],$content,$mkey);
$stmt->execute();
fclose($handle);
$i++;
}
没有发生错误,其他 2 个字段 mkey 和 filename 填充在数据库列中,但内容没有,$content 在我的浏览器中显示为 print_r,我确定 $content 变量不为空,但 mysql 没有显示任何内容内容.
no error occured,and the other 2 fields mkey and filename are filled in database columns,but the content no,$content shown with print_r in my browser and i sure the $content variable is not empty,but mysql shows me nothing of the content.
推荐答案
RTM ;-)
如果变量的数据大小超过最大值.允许的数据包大小(max_allowed_packet),您必须在类型中指定 b 并使用 mysqli_stmt_send_long_data() 以包的形式发送数据.
If data size of a variable exceeds max. allowed packet size (max_allowed_packet), you have to specify b in types and use mysqli_stmt_send_long_data() to send the data in packets.
所以我自己从来没有这样做过,但我认为它需要根据您的代码和 函数文档页面上的示例:
So I have never done this myself but i would assume it needs to look something like this based on your code and the example on the functions doc page:
$filepath = ini_get('upload_tmp_dir')."/".basename($_FILES['file'.$i]['tmp_name']);
$filepath = addslashes($filepath);
$handle = fopen($filepath, "rb");
$content = null;
$stmt = $mysqli->prepare("INSERT INTO attachment (filename,filecontent,mkey) VALUES (?,?,?)");
$stmt->bind_param("sbi",$_FILES['file'.$i]['name'], $content, $mkey);
while (!feof($handle)) {
// $maxPacketSize would be the size of your max packet setting for mysql,
// or something safely assumed to be below it
$stmt->send_long_data(1, fread($handle, $maxPacketSize));
}
fclose($handle);
$stmt->execute();
这篇关于php print_r 中显示的二进制文件内容但未保存在 mysql 中的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:php print_r 中显示的二进制文件内容但未保存在
基础教程推荐
- YouTube API v3 点赞视频,但计数器不增加 2022-01-01
- PHP 类:全局变量作为类中的属性 2021-01-01
- 学说 dbal querybuilder 作为准备好的语句 2022-01-01
- Cron Jobs 调用带有变量的 PHP 脚本 2022-01-01
- 有什么方法可以用编码 UTF-8 而不是 Unicode 返回 PHP`json_encode`? 2021-01-01
- 如何替换eregi() 2022-01-01
- 在PHP中根据W3C规范Unicode 2022-01-01
- PHP PDO MySQL 查询 LIKE ->多个关键词 2021-01-01
- 如何在 Laravel 中使用 React Router? 2022-01-01
- 如何在 Laravel 5.3 注册中添加动态下拉列表列? 2021-01-01
