【问题标题】:Displaying blob data from a Firebird database using PHP使用 PHP 显示来自 Firebird 数据库的 blob 数据
【发布时间】:2020-12-31 23:03:40
【问题描述】:

所以,我有这个 Firebird 数据库,其中包含一个我正在尝试显示的“照片”列。

这是我到目前为止所做的:

  • 由于内容类型未知(我不是创建数据库的人,并且没有指示类型的列)。

  • 从 blob 数据的前 20 个字符我猜它是一个 bmp:

    “01 00 00 01 36 65 01 00 42 4D 36 65 01 00 00 00”

    “42 4D”出现在我得到的每张照片中。

这是一个示例代码:

// Before this : code to connect, run a query to get the table and fetch the result as object ( everything works fine until here)

$blob_data = ibase_blob_info($row->PHOTO);
$blob_hndl = ibase_blob_open($row->PHOTO);

$bl = ibase_blob_get($blob_hndl, $blob_data[0]);
header('Content-type : image/x-xbitmap');
ibase_blob_echo($row->PHOTO);
 
echo "<dt><strong>Technician Image:</strong></dt><dd>" . 
     '<img src="data:image/x-xbitmap  ;base64,'.
     base64_encode($bl).
      '" width="290" height="290">' . "</dd>";

$filename = $bl ? dirname(__FILE__)."/img/product__$NUM.bmp" : dirname(__FILE__)."/img/no_pic.bmp";

if ($bl) fwrite(fopen($filename, 'w'), $bl);

如你所见,我已经尝试过:

  • 使用“ibase_blob_echo”显示 blob 数据
  • 使用 img 标签显示 blob
  • 另存为文件

第一个显示 blob 的原始数据,第二个什么都没有,第三个导致文件损坏。

关于我尝试过的 Content-type 标头

  • 图像/bmp ,x-portable-bitmap, x-xbitmap , jpg, gif, png

现在我没有主意了。

【问题讨论】:

  • 发布前 20 个字节的十六进制。
  • "01 00 00 01 36 65 01 00 42 4D 36 65 01 00 00 00" 我得到的每张照片中都有“42 4D”。
  • 我知道这是旧的,但你能告诉我你是如何在数据库中插入 blob 的吗?我试图插入blob,但它只是插入0x000usi354sf0000

标签: php firebird


【解决方案1】:

bitmap 在位置 0 处有 0x42 0x4D,然后是 4 个字节的文件大小(0x36 0x65 0x01 0x00)。在转储中,您发布的字节 5-8(在 BMP 标头之前)和字节 11-14(在 BMP 标头之后的文件大小)是相同的,所以看起来 blob 有(猜测工作):

  • 4 字节:某种特定于应用程序的图像类型 nr (?)
  • 4字节:文件大小(与0x42 0x4D后相同)
  • 实际位图文件

您可能想检查跳过前 8 个字节是否足以让它工作,然后我会检查这是否适用于所有文件(可能有不止一种文件类型!)

【讨论】:

  • 跳过前 8 个字节就像一个魅力。我使用了一个简单的 substr() 并且它有效。感谢您的回答。
猜你喜欢
  • 2019-07-01
  • 2020-09-05
  • 2012-02-03
  • 2018-09-07
  • 1970-01-01
  • 2019-02-01
  • 2017-07-15
  • 1970-01-01
  • 2015-07-06
相关资源
最近更新 更多