我后端存儲大文件的時候是切分存儲的,對一個大文件切分成了n塊,存在Mongodb中?,F(xiàn)在在前端采用JS實現(xiàn)多線程下載,目前的思路是在前端發(fā)錢n個ajax,然后利用promise.all等待這n個請求的返回,返回后數(shù)據(jù)拼接然后設(shè)置a標(biāo)簽的download屬性進(jìn)行下載。目前存在兩個問題:1.因為我是等所有的數(shù)據(jù)都回來后再整合下載的,所以數(shù)據(jù)先是在內(nèi)存中的,對于一個很大的文件,比如說1G或2G這樣顯然是不合理的。2.再說斷點續(xù)傳問題,思路為點擊下載這個文件,前端先讀取這個文件,然后判斷這個文件的第i(0<i<n)塊是否已經(jīng)下載了,僅下載未下載的部分,但是問題是JS無法寫入到本地文件啊。想請問各位碼友有什么好的解決方案嗎?有一個朋友說看能不能使用瀏覽器的代理,就是說瀏覽器每次請求的是這個代理,然后在代理中實現(xiàn)文件的各種操作,但是他又沒有具體說這個代理究竟是個什么東西,具體該怎么實現(xiàn),所以不太好搜索材料。希望各位碼友不吝賜教。
JS如何實現(xiàn)大文件“多線程”下載及斷點續(xù)傳
30秒到達(dá)戰(zhàn)場
2019-03-11 16:14:50