【问题标题】:saving file in database using unpack php使用 unpack php 将文件保存在数据库中
【发布时间】:2019-02-07 07:58:16
【问题描述】:
$data = '0x'.unpack('H*hex', file_get_contents($tmp_name))['hex'];

我正在尝试使用上述代码将文件数据存储到我的数据库中。然后我检索它并将其用作下载

header('Content-Description: File Transfer');
header("Content-Transfer-Encoding: Binary");
header('Content-Disposition: attachment; filename="'.basename( $response->strFileName ).'"');
header('Cache-Control: must-revalidate');
header('Content-Length: '.$response->intSize);
echo $response->binFile;

其中$response->binFile 是来自服务器的响应,即我存储上述代码中的数据的列。

这适用于 pdf 文件,但不适用于图像 jpg/png。图像的大小比原始文件小,我得到错误

当我下载并打开它时上传的图像。 PDF没问题

右边是原图,左边是上传到数据库然后下载的图片。使用上面的代码

我不知道是否值得一提,但我下载的图像没有尺寸,如下所示:

右侧上传,左侧下载原件

【问题讨论】:

  • 你在用unpack 代码做什么...?!您是否尝试过比较服务器对原始文件的响应以查看差异可能在哪里?您是否尝试过设置适当的 Content-Type 标头?
  • 唯一的区别是我将显示示例图像属性的大小
  • @deceze 请参阅更新的 OP。图像大小有细微差别。但是在 PDF 中是一样的。
  • 好吧,即使大小相同。同样,使用差异程序或十六进制编辑器来比较实际文件内容。如果那还不行,那就更清楚地了解我们在那里看到的内容。是什么程序告诉你它“不支持这种格式”?
  • @deceze 它是一个默认的 Windows 图像查看器。让我看看你的建议

标签: php image pdf unpack


【解决方案1】:

我使用了下面的标题。并解决了问题

ob_clean();
header("Content-type: ".$response->strExtension.""); 
header("Cache-Control: no-store, no-cache");  
header("Content-length: ".$response->intSize.""); 
header("Content-Disposition: attachment; filename=".basename($response->strFileName).""); 
echo base64_decode($response->binFile);

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2015-06-19
    • 1970-01-01
    • 2014-03-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多