php调用 firebird,使用PHP从Firebird数据库显示Blob数据

因此,我有这个firebird数据库,其中包含我要显示的“照片”列.

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

>因为,内容类型是未知的(我不是创建数据库的人,并且没有表示该类型的列).

>从blob数据的前20个字符中,我猜它是bmp.

这是一个示例代码:

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 "

Technician Image:" .

'' . "

";

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

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

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

>使用“ ibase_blob_echo”显示斑点数据

>使用img标签显示blob

>将其另存为文件

第一个显示Blob的原始数据,第二个不显示任何内容,第三个显示损坏的文件.

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

>图片/ bmp,x便携式位图,x-x位图,jpg,gif,png

现在我没主意了…

解决方法:

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

> 4个字节:某种特定于应用程序的图像类型nr(?)

> 4个字节:文件大小(与0x42 0x4D之后相同)

>实际位图文件

您可能要检查跳过前8个字节是否足以使其正常工作,然后检查所有文件是否通用(也许有多个文件类型!)

标签:php,firebird

来源: https://codeday.me/bug/20191013/1909360.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值