0

我尝试显示存储在数据库中的图像。我用它写的

$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,并且显示了更多内容,所以我认为二进制数据在任何地方都被剪切了。数据库列是 varbinary(max)

请让我们不要讨论在数据库中存储 blob 是否合理 :) :)

4

2 回答 2

1

解决方案是增加 php.ini 中 odbc 的最大接受字符串长度。它设置为 4069 个字符

于 2013-10-15T08:19:39.663 回答
0
  • 您是否尝试将您的列定义为 BLOB(最多 2 GB)?
  • 你确定,完整的图像被存储(也许这个功能是错误的)
于 2013-10-14T11:34:23.030 回答