解决js流式下载工具 stream-saver 在部分网络环境下,下载时浏览器右上角不弹出文件下载框,无法正常下载文件的问题

观察到:部分网络情况下,stream-saver无法正常下载文件。
打开浏览器控制台,发现stream-saver在请求此地址https://jimmywarting.github.io/StreamSaver.js/mitm.html?version=2.0.0
当此地址能请求通时,能够下载文件成功,请求失败时,则下载文件一定无法成功。
查stream-saver源码:

const streamSaver = {
    createWriteStream,
    WritableStream: global.WritableStream || ponyfill.WritableStream,
    supported: true,
    version: { full: '2.0.5', major: 2, minor: 0, dot: 5 },
    mitm: 'https://jimmywarting.github.io/StreamSaver.js/mitm.html?version=2.0.0'
  }

原来,stream-saver访问了一个github地址做mitm,这在国内当然无法成功访问。
将mitm.html的内容保存在自持有的项目public目录下,并在使用stream-saver时进行如下修改:

import streamSaver from 'streamsaver'

fetch(url, {
	method: 'GET',
}).then(res => {
	streamSaver.mitm = '/mitm.html' // 增加此行代码
	const fileStream = streamSaver.createWriteStream(fileName, { size: file.size })
	return res.body.pipeTo(fileStream).then(() => console.log('下载完成'))
})

此时,mitm.html能够正常访问,但又出现sw.js无法下载的问题。
查阅mitm.html源码,它又引入了一个sw.js,做ServiceWorker代理下载。

function registerWorker() {
		return navigator.serviceWorker.getRegistration('./').then(swReg => {
			return swReg || navigator.serviceWorker.register('sw.js', { scope: './' })
		}).then(swReg => {
			const swRegTmp = swReg.installing || swReg.waiting

			scope = swReg.scope

			return (sw = swReg.active) || new Promise(resolve => {
				swRegTmp.addEventListener('statechange', fn = () => {
					if (swRegTmp.state === 'activated') {
						swRegTmp.removeEventListener('statechange', fn)
						sw = swReg.active
						resolve()
					}
				})
			})
		})
	}

访问https://github.com/jimmywarting/StreamSaver.js/blob/master/sw.js 复制其内容,保存在自持有的mimt.html同级目录下

问题成功解决

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值