二进制文件内容以 PHP print_r 显示,但不保存在 MySQL 中


binary file content shown in php print_r but not saved in mysql

我必须将输入字段中的文件保存到数据库,我会这样做:

    $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 和文件名填写在数据库列中,但内容没有,$content在我的浏览器中显示print_r,我确定 $content 变量不为空,但 MySQL 没有向我显示任何内容。

RTM ;-)

如果变量的数据大小超过允许的最大数据包大小 (max_allowed_packet),则必须在类型中指定 b,并使用 mysqli_stmt_send_long_data() 以数据包形式发送数据。

所以我自己从来没有这样做过,但我认为它需要根据您的代码和函数文档页面上的示例看起来像这样:

    $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();