首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >失败,从vuejs通过axios下载zip文件

失败,从vuejs通过axios下载zip文件
EN

Stack Overflow用户
提问于 2020-08-14 09:11:15
回答 1查看 1.4K关注 0票数 1

我对.zip文件在Vue.js中的下载有问题。这是我的密码。

代码语言:javascript
复制
if (response) {
                    let fileName = response.headers["x-suggested-filename"]
                    var fileUrl = window.URL.createObjectURL(new Blob([response.data], {type: "application/zip"}));
                    var fileLink = document.createElement("a");
                    fileLink.href = fileUrl;
                    fileLink.setAttribute("download", fileName);
                    document.body.appendChild(fileLink);
                    fileLink.click();
                } else {
                    this.$notify.error({
                        title:    "Request failed",
                        message:  "No response received. ",
                        duration: 0,
                    });
                }

这里是我的响应头

我下载了这个文件,但是它不起作用.

但是链接它的工作,它意味着,后端站点没有问题。我怎样才能修复这个错误?

,这是我来自服务器.的代码

代码语言:javascript
复制
public function export(array $params)
{
    if (!$this->load($params, '') || !$this->validate()) {
        throw new BadRequestHttpException();
    }

    $exporter = new ProfileExporter($this->format);
    $zipFile = new ZipFile();

    $exporter->exportToZipFile($zipFile, $this->profileId, $params);
    $fileName = 'df-profile-data-export-' . \Yii::$app->formatter->asDate('now', 'yyyy-MM-dd') . '.' .
        $this->getFileExtension();

    $stream = fopen('php://memory', 'w+');
    $zipFile->writeToStream($stream);
    \Yii::$app->response->headers->add('X-Suggested-Filename', $fileName);

    \Yii::$app->response->sendStreamAsFile($stream, $fileName, [
        'mimeType' => 'application/zip',
    ]);
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-08-14 09:46:44

要通过axios下载文件,您应该在axios头中设置responseType

代码语言:javascript
复制
responseType:'blob'
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63409887

复制
相关文章

相似问题

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