doudeng2057 2019-07-03 06:48
浏览 126
已采纳

XAMPP,PHP:echo为从数据库读取的blob添加了两个空格

I read blob (word 2010 document) from mysql database and store it in $data variable. When I simply store that data directly in PHP like so:

file_put_contents('c:\\temp\\dump.docx', $data);

I can open dump.docx in Word (size matches original file). If I attempt to send $data like this:

ob_start();
header('Content-disposition: attachment; filename=' . $name);
header('Content-type: ' . $type);
ob_clean();
echo $data;
ob_end_flush();
exit;

The stored file is two bytes longer. There are two spaces in front:

Downloaded word doc viewed in hex editor with two extra spaces in front

To check if I somehow do not output those spaces, I called ob_get_contents() just before echo and dumped content to a file. File has zero bytes. So it looks like echo is producing those two bytes.

  • 写回答

1条回答 默认 最新

  • douci2015 2019-07-03 07:14
    关注

    Here's post that helped me: https://drupal.stackexchange.com/questions/163628/extra-space-at-beginning-of-downloaded-image/163644

    ob_start was already called ealier. I needed to call only ob_clean() before sending content.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?