0

我正在使用以下脚本来测试插入然后读取 blob 数据。

插入脚本:

include('session.php');

$provider      =$_POST['provider_id'];
$trd_period    =$_POST['trading_period_month'];
$pdf_statement =stream_get_contents(fopen($_FILES['pdf_statement']['tmp_name'], 'rb'));
$pdf_statement_clean=addslashes($pdf_statement);


$insert="update rd_provider_statement
         set pdf_statement='".$pdf_statement_clean."', creation_user_id='SCO'
         where  provider_id='".$provider."' and trading_period_month='".$trd_period."'";

mysql_query($insert);
mysql_query("COMMIT"); 

echo mysql_error();

下载脚本:

include('session.php');

//Gather Post Variables
$TP_Month  =$_POST["trading_period_month"];
$provider =$_POST["provider_id"];
$TP_format =substr($TP_Month, 0, 7);

//Download Statement

$sql_qry="select *
          from   rd_provider_statement
          where  provider='".$provider."' and trading_period_month='".$TP_Month."'";
$sql_err_no=sql_select($sql_qry,$sql_res,$sql_row_count,$sql_err,$sql_uerr);

$row = mysql_fetch_assoc($sql_res);
$bytes =stripslashes($row['pdf_statement']);
header("Content-type: application/pdf");
header('Content-disposition: attachment; filename="'.$provider.'statement'.$TP_format.'"');
print $bytes;

但是,下载文件后,由于格式不受支持,因此无法打开。我使用另一个页面上的脚本基础从数据库中下载 blob 数据,但是此处插入数据库是由 mysql 过程而不是 PHP 完成的。我认为是我的插入脚本导致了问题。

4

3 回答 3

1

尝试使用mysql_real_escape_string()而不是 addslashes(). 它可能会解决你的问题。

对于调试,您可以md5()在插入数据库之前计算字符串的值,然后在检索它之后计算。我敢打赌你会得到不同的哈希值,这意味着你没有正确插入它并且你的二进制数据在插入数据库时​​会被破坏。

旁注:

于 2012-07-12T06:30:22.303 回答
1

通常,您不希望在 http 标头描述之前有任何输出代码。见http://php.net/manual/en/function.header.php

将文件名和其他文件信息存储在会话中,然后在另一个页面中访问它们。

您需要检查的几件事:

  • my.ini 中的 max_allowed_pa​​cket 应该等于或大于您希望存储在数据库中的文件大小
  • 检查您选择的数据类型是否适合您将存储的文件。有小斑点、博客、中斑点和长斑点。您可能想尝试最大的长斑点。
  • 我不确定这个,但你是否已经检查过 file_get_contents 是否有效:

mysql_real_escape_string(file_get_contents($file))

于 2012-07-12T06:50:11.937 回答
0

这是我的替代答案。

首先是更新查询:

准备文件(假设你的文件不是二进制文件):

    $tmpName = $_FILES["pdf_statement"]["tmp_name"];
    $fp = fopen($tmpName, 'r');
    $data = fread($fp, filesize($tmpName));
    $data = addslashes($data);
    fclose($fp);



$insert="update rd_provider_statement
         set pdf_statement='".$data."', creation_user_id='SCO'
         where  provider_id='".$provider."' and trading_period_month='".$trd_period."'";

下载:

enter code here

$sql_qry="select provider_id, pdf_statement
          from   rd_provider_statement
          where  provider='".$provider."' 
         and trading_period_month='".$TP_Month."'";

$sql_err_no=sql_select($sql_qry,$sql_res,$sql_row_count,$sql_err,$sql_uerr);

$row = mysql_fetch_assoc($sql_res);
    $name=$row['provider_id'];
    $file=$row['pdf_statement'];


header("Content-Disposition: attachment; filename=\".$name_statement.$TP_format.\";" );
echo $file;

希望它有帮助=)

于 2014-08-25T17:00:26.297 回答