Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/tensorflow/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用PHP显示Firebird数据库中的blob数据_Php_Firebird - Fatal编程技术网

使用PHP显示Firebird数据库中的blob数据

使用PHP显示Firebird数据库中的blob数据,php,firebird,Php,Firebird,所以,我有一个Firebird数据库,其中有一个“照片”栏,我正试图显示它 以下是我迄今为止所做的工作: 因为内容类型未知(我不是创建数据库的人,也没有列指示类型) 根据blob数据的前20个字符,我猜它是bmp: “01 00 00 01 36 65 01 00 42 4D 36 65 01 00” 我得到的每一张照片中都有“424D” 下面是一个示例代码: // Before this : code to connect, run a query to get the table a

所以,我有一个Firebird数据库,其中有一个“照片”栏,我正试图显示它

以下是我迄今为止所做的工作:

  • 因为内容类型未知(我不是创建数据库的人,也没有列指示类型)

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


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

    我得到的每一张照片中都有“424D”

下面是一个示例代码:

// 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);
//在此之前:编写连接代码,运行查询以获取表并将结果作为对象获取(在此之前一切正常)
$blob_data=ibase_blob_info($row->PHOTO);
$blob_hndl=ibase_blob_open($row->PHOTO);
$bl=ibase_blob_get($blob_hndl,$blob_data[0]);
标题(“内容类型:图像/x-xbitmap”);
ibase_blob_echo($row->PHOTO);
回显“技术人员图像:”。
'' . "";
$filename=$bl?dirname(_文件).“/img/product__$NUM.bmp”:dirname(_文件).“/img/no_pic.bmp”;
如果($bl)fwrite(fopen($filename,'w'),$bl);
正如你所看到的,我试图:

  • 使用“ibase\U blob\U echo”显示blob数据
  • 使用img标记显示blob
  • 将其另存为文件
第一个显示blob的原始数据,第二个不显示任何内容,第三个导致文件损坏

关于我尝试过的内容类型标题

  • 图像/bmp、x-portable-bitmap、x-xbitmap、jpg、gif、png
现在我没有主意了。

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

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

您可能想检查跳过前8个字节是否足以使其正常工作,然后我会检查这是否适用于所有文件(可能有多种文件类型!)

公布前20个字节的十六进制。“01 00 00 01 36 65 00 42 4D 36 65 01 00 00 00 00 00”42 4D在我得到的每一张照片中都有。跳过前8个字节真是妙不可言。我使用了一个简单的substr(),它成功了。谢谢你的回答。