首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Yii2 -下载损坏的文件

Yii2 -下载损坏的文件
EN

Stack Overflow用户
提问于 2021-02-08 09:11:20
回答 2查看 305关注 0票数 0

我正在开发现有的产品,并试图解决下载xlsx文件的问题。当我通过文件管理器下载文件时,文件是正常的。但是当我通过Yii应用下载文件时,文件被破坏了。

这是我的密码

代码语言:javascript
复制
public function actionCallLog($hash, $filename)
    {
        var_dump(
            $hash, $filename
        );

        ignore_user_abort(true);
        set_time_limit(0);
        

        $path = "/var/www/html/uploads/call_log/".$hash.'/';

        $dl_file= basename($filename).'.xlsx';
        if (!file_exists($path.$dl_file)) {
            $dl_file= basename($filename).'.csv';
        }
        $fullPath = $path.$dl_file;

        if ($fd = fopen ($fullPath, "r"))
        {

            $fsize = filesize($fullPath);
            $path_parts = pathinfo($fullPath);
            $ext = strtolower($path_parts["extension"]);
            switch ($ext)
            {
                case "xlsx":
                header('Content-Description: File Transfer');
                header("Content-type: application/xlsx");
                header("Content-Disposition: attachment; filename=\"".$path_parts["basename"]."\"");
                break;
                case "csv":
                header('Content-Description: File Transfer');
                header("Content-type: application/csv");
                header("Content-Disposition: attachment; filename=\"".$path_parts["basename"]."\"");
                break;
                // add more headers for other content types here
                default;
                header('Content-Description: File Transfer');
                header("Content-type: application/octet-stream");
                header("Content-Disposition: filename=\"".$path_parts["basename"]."\"");
                break;
            }
            header("Content-length: $fsize");
            header("Cache-control: private");
            header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
            header('Expires: 0');
            header('Pragma: public');
            while(!feof($fd))
            {
                $buffer = fread($fd, 2048);
                echo $buffer;
            }
        }
        fclose ($fd);
        exit;
    }

有人知道问题出在哪里吗?

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-02-09 15:25:07

尝试关闭所有头指令(以及"echo $buffer;“,因为屏幕上可能有很多),并查看打开文件下载的url时屏幕上是否打印了警告或错误。

如果损坏的文件有一个大小,您的代码实际上可能会发出警告或生成其他输出,这些输出将成为文件的一部分,因为它也是回显的。显然,代码输出的额外纯文本会将正确的xlsx转换为损坏的文件。您可以通过在文本编辑器中打开损坏的文件来获取文本,就像它在纯文本中显示的那样(可能在开始时)。

票数 0
EN

Stack Overflow用户

发布于 2021-02-08 11:54:24

尝试添加响应格式

代码语言:javascript
复制
\Yii::$app->response->format = \yii\web\Response::FORMAT_RAW;

对于xlsx,内容类型应该是

代码语言:javascript
复制
'application/vnd.ms-excel'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66098698

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档