我在 mysql 数据库中将一个 pdf 文件保存为 MEDIUMBLOB 文件。我使用以下代码下载它。下载的文件与原始文件的大小和文件类型相同,但无法正常打开。可能是什么问题以及如何解决?
$emp_no=55;
$DOB="2014-09-03";
$query="SELECT file_name, file_type, file_size, file_data FROM document WHERE emp_no=$emp_no AND DOB='$DOB'";
$retval=mysqli_query($non,$query);
$row=mysqli_fetch_array($retval,MYSQL_ASSOC);
$file_name=$row['file_name'];
$file_type=$row['file_type'];
$file_size=$row['file_size'];
$file_data=$row['file_data'];
header("Content-length: $file_size");
header("Content-type: application/pdf");
header("Content-Disposition: attachment; filename=$file_name");
echo $file_data;
最佳答案
在记事本中打开 downloaded.pdf,您会看到文件顶部有 PHP 错误通知,这些会损坏所有下载的文件。
一些解决方案:
- 修复它们 ;-)
- 通过
error_reporting(E_ERROR);
在您的 PHP 代码的第一行关闭 E_NOTICE 错误报告 - 构建您自己的 custom error reporting mechanics并通过
ini_set('display_errors', 0);
关闭向浏览器打印错误,这样它们就不会弄乱下载的文件
你可以修复这些,或者添加一个
关于php - 如何使用 php 下载保存在 mysql 数据库中的 pdf 作为 MEDIUMBLOB 数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27969743/