客户公司的SQLServer2008的一个生产数据库才1年多就高达18G之巨,原来是系统里面的图片直接以html">16进制字符串的形式存储在数据库的。要用PHP显示在html页面上,我还耗费了不上时间。
1
2
3
4
5
6
7
8
9
10
11
|
<?php
// 从数据库读出来的:图片的十六进制形式字符串
$icon_hex = '89504e470d0a1a0a0000000d494844520000001c00000012010300000072c92ca'
. '700000006504c5445000000ffffffa5d99fdd0000003f49444154089963603e6f60c000266cce1'
. 'b1f8010cc07406220c2febcf10724e2ffe7ff7082f90303e76466062061ccc0603999d90048d81'
. 'b30d809f3400800c0921ea36f9b656d0000000049454e44ae426082' ;
$imgdata = base64_encode (pack( 'H*' , $icon_hex ));
echo '<img src="data:image/png;base64,' . $imgdata . '" />' ;
?>
|
参考资料:http://php.net/manual/en/function.imagecreatefromstring.php base64转成图片
注意的一点是:在img标签显示时,一定要加文件头说明:"data:image/png;base64,",这个地方弄了我好久。
以上这篇PHP里面把16进制的图片数据显示在html的img标签上(实现方法)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。