我尝试显示存储在数据库中的图像。我写的
$image = file_get_contents($testPfad);
$dateigroesse = filesize($testPfad);
$arrData = unpack("H*hex", $image);
$data_string = "0x".$arrData['hex'];
$sql = "INSERT INTO EHS.dbo.T_Signaturen (UnterschriftsDateiName,UnterschriftsBild,Dateigroesse,terminID) VALUES (
'".$unterschriftsFileName."',
CONVERT(varbinary(max),'$data_string'),
'".$dateigroesse."',
'384_234')";
echo '<hr>'.$sql;
insert($sql);
使用此代码,我输出图像。
header("Content-type: image/jpeg");
$query = "SELECT Dateigroesse, CONVERT(varchar(max), UnterschriftsBild) as content_data FROM EHS.dbo.T_Signaturen WHERE ID = '10'";
$result = query($query);
$content = $result[1]["content_data"];
$filesize = $result[1]["Dateigroesse"];
$content = substr ($content, 2); // entfernt 0x
$content = pack("H*", $content);
print $content;
一切正常,但只显示图像的一部分。我将图像大小从 20kb 减小到 2kb,并且显示了更多内容,因此我认为在任何地方切割二进制数据。数据库列是一个变量(最大值)
请不要让我们讨论将 blob 存储在数据库中是否合理:) :)
解决方案是增加 php.ini 中 odbc 接受的最大字符串长度。它设置为 4069 个字符
- 您是否尝试将列定义为 BLOB(最多 2 GB)?
- 您确定存储了完整的图像(也许该功能是错误的)