在响应php中返回二进制代码而不是字符串

时间:2013-02-06 05:34:14

标签: php excel binary

我想用php读取excel文件并将其内容发送到客户端。我真正想做的是通过更改内容类型和其他html标头强制浏览器下载文件而不是显示其内容。一切正常,用户可以下载文件,但当他试图打开时,内容不会以正确的格式和形状显示。我想到的是,我不应该以unicode字符串发送响应,并且必须以二进制格式进行,excel可以知道它。这是我目前的代码:

$filename = $_GET['file'];
        $ext = $_GET['type'];
        $filename .= '.' . $ext;
        $path = "../generatedReports/" . $filename;
        header('Content-type: application/vnd.ms-excel;');
        header('Content-Disposition: attachment; filename=' . $filename);
        header("Pragma: public");
        header("Expires: 0");
        header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
        header("Cache-Control: public", false);
        header("Content-Description: File Transfer");
        header("Accept-Ranges: bytes");
        header("Content-Transfer-Encoding: binary");
        header("Content-Length: " . filesize($path));
        $size = filesize($path);
        $f = fopen($path, 'r');
        $content = fread($f, $size);
        echo $content;

任何解决方案?

2 个答案:

答案 0 :(得分:0)

请尝试使用以下代码,

echo unicode2utf8(hexdec("00CE")); // Result: Î

// Or the function that will recognize U+ in front of string, and will skip it to show the character
function unicodeCodePointToChar($str) {
    if (substr($str,0,2) != "U+") return $str;
    $str = substr($str,2); // Skip U+
    return unicode_to_utf8(array(hexdec($str)));
}
echo unicodeCodePointToChar("U+00CE"); // Result: Î

答案 1 :(得分:0)

我的问题由answer解决了。我已将代码更改为:

$filename = $_GET['file'];
            $ext = $_GET['type'];
            $filename .= '.' . $ext;
            $path = "../generatedReports/" . $filename;
            header('Content-type: application/vnd.ms-excel;');
            header('Content-Disposition: attachment; filename=' . $filename);
            header("Pragma: public");
            header("Expires: 0");
            header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
            header("Cache-Control: public", false);
            header("Content-Description: File Transfer");
            header("Accept-Ranges: bytes");
            header("Content-Transfer-Encoding: binary");
            ob_clean();   // discard any data in the output buffer (if possible)
            flush();      // flush headers (if pos
            readfile($path);

一切都很好。