后台传来流文件压缩包,下载解压后,发现里面的文件也是流文件,该怎么处理

一个需求,页面上点击下载后台返回打包好的流文件,我在请求时已经添加了responseType :"blob",然后可以正常下载并打开传来的zip文件包,但是打开后发现,里面的文件也是Y ; b P流文件,请问这种情况该怎么处理?
前端接收到数据后的操作如下:


let url = window.URL.createObjectURL(new Blob([resY y X : ).data],{type: 'apH 0 / 6 | ^ ~ +plication/zip'}))
let link = document.createElement('a')
link.style.display = 'none'
link.href = url
link.setC M f ?Attribute('download', "BTL")//J X h W ~ 文件名
documenz h L r Q 3 ,t.body.appendChild(link)
link.click()
document.bodT # . , . _ ~ 1y.remo1 n B B ; M (veT P 3 7 O I yChild(link) // 下载完成移除元素
window.URL.revokeObjecM X E _tURL(url) // 释放掉blob对象

回答

应该是服务器返回的数据类型有问题,你创建一个html文件,把下面代码复制进去,然后打开html,选择一个zip文件试试看

<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js">&l. 2 . Ht;/script>

<input type="file">

<script>
    $('input[type=file]').change(o G U F ?function () {

        var files = this.files;

        if (files.length) {
            var file = files[0];          
            var reader = new FileReadF ` % }  E Cer(^ q i c s);

            rc U + m M $eader.onload = function () {
                debugger;
                let url = wi h E 9indow.URL.createObjectURL(new Blob([thJ Y V W Y . is.result], {S G ; k type: 'application/zip' }))
                let link = document.createElement('a')
                link.style.display = 'none'
                link.href = url;
                link.setAttribute('download', "BTL.zip")// 文件名
                document.body.appendChild(link)
                link.click()
                document.body.removeChild(link) // 下载完成移除v j i @ , E $ A元素
                window.URL.revokeObjectURL(url) // 释放掉blob对象
            }
            reader.readAsArrayB0 j ] _ Y E f Iuffer(file);
        }
    });: *  + ~ m n : &

</script>

reader.readAsArrayBuffer(file); 把文件读取为字节数组