web前端Tips:斷點(diǎn)續(xù)傳如何實(shí)現(xiàn)鳄炉?

<p class="image-package"><img class="uploaded-img" src="https://upload-images.jianshu.io/upload_images/28907010-c855c60155108346.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" width="auto" height="auto"/></p><p>在Web前端中實(shí)現(xiàn)斷點(diǎn)續(xù)傳功能的一種常見方式是使用HTTP Range請(qǐng)求和文件分片上傳。</p><p><strong>以下是一個(gè)簡(jiǎn)單的斷點(diǎn)續(xù)傳實(shí)現(xiàn)的步驟:</strong></p><ol><li><p>前端將要上傳的文件分成多個(gè)固定大小的片段(chunk),例如每個(gè)片段的大小為1MB。</p></li><li><p>當(dāng)用戶選擇上傳文件時(shí)因篇,前端發(fā)送一個(gè)初始請(qǐng)求到服務(wù)器,詢問服務(wù)器當(dāng)前已上傳的文件大小(如果之前有上傳過該文件)竞滓。</p></li><li><p>服務(wù)器通過響應(yīng)返回已上傳的文件大小給前端咐吼。</p></li><li><p>前端根據(jù)服務(wù)器返回的已上傳文件大小,計(jì)算出還需要上傳的文件片段商佑。</p></li><li><p>前端使用File API的slice方法將剩余的文件分片進(jìn)行上傳锯茄。同時(shí),在每次上傳片段時(shí)茶没,設(shè)置HTTP請(qǐng)求的Range頭部肌幽,指示上傳的起始位置。</p></li><li><p>服務(wù)器接收到文件片段后抓半,根據(jù)Range頭部確定文件的上傳位置喂急,并將數(shù)據(jù)追加到對(duì)應(yīng)的位置上。</p></li><li><p>重復(fù)步驟5-6笛求,直到所有文件片段都上傳完成廊移。</p></li><li><p>可選:前端可以在每次上傳完一個(gè)片段后,更新進(jìn)度條或顯示上傳進(jìn)度涣易。</p></li></ol><p>需要注意的是画机,服務(wù)器端也需要相應(yīng)的邏輯來處理斷點(diǎn)續(xù)傳的請(qǐng)求,并將上傳的文件片段正確拼接到最終的文件中新症。</p><p>以上是一個(gè)基本的斷點(diǎn)續(xù)傳的實(shí)現(xiàn)思路步氏,具體的代碼實(shí)現(xiàn)可能會(huì)因具體的技術(shù)框架和需求而有所不同。</p><p><strong>具體代碼如何實(shí)現(xiàn)</strong></p><p>以下是一個(gè)基于JavaScript和Node.js的簡(jiǎn)單示例:</p><p>前端代碼(使用Fetch API):</p><pre>const?uploadFile?=?async?(file)?=>?{
??const?CHUNK_SIZE?=?1??1024??1024;?//?1MB

??let?start?=?0;
??let?end?=?Math.min(CHUNK_SIZE,?file.size);

??while?(start?<?file.size)?{
????const?chunk?=?file.slice(start,?end);
????const?formData?=?new?FormData();
????formData.append('file',?chunk);

????await?fetch('/upload',?{
??????method:?'POST',
??????body:?formData,
??????headers:?{
????????'Content-Range':?bytes&nbsp;${start}-${end&nbsp;-&nbsp;1}/${file.size},
??????},
????});

????start?=?end;
????end?=?Math.min(start?+?CHUNK_SIZE,?file.size);
??}

??console.log('Upload?complete');};const?fileInput?=?document.getElementById('file-input');fileInput.addEventListener('change',?(event)?=>?{
??const?file?=?event.target.files[0];
??uploadFile(file);});</pre><p>后端代碼(使用Express.js):</p><pre>app.post('/upload',?(req,?res)?=>?{
??const?rangeHeader?=?req.headers['content-range'];
??const?fileSize?=?parseInt(rangeHeader.split('/')[1]);
??const?[start,?end]?=?rangeHeader.replace(/bytes=([0-9]+)-([0-9]+)/,?'1-2').split('-');

??//?在此處處理文件上傳邏輯徒爹,將接收到的文件片段追加到最終文件中
??//?例如荚醒,可以使用fs模塊將片段寫入磁盤上的文件

??res.sendStatus(200);});</pre><p>請(qǐng)注意,以上示例是一個(gè)簡(jiǎn)化的版本隆嗅,實(shí)際的代碼可能需要添加錯(cuò)誤處理界阁、進(jìn)度更新等功能。另外胖喳,您還需要根據(jù)自己的具體需求和技術(shù)棧進(jìn)行相應(yīng)的調(diào)整和完善泡躯。</p><p><strong>斷點(diǎn)續(xù)傳中,如何判斷是否為同一文件</strong></p><p>在斷點(diǎn)續(xù)傳中丽焊,判斷是否為同一文件可以使用文件的唯一標(biāo)識(shí)來進(jìn)行比較较剃。通常情況下,我們可以使用文件的名稱或者文件的MD5值作為文件的唯一標(biāo)識(shí)技健。</p><p>具體實(shí)現(xiàn)方式如下:</p><p>前端:</p><ol><li><p>在選擇文件時(shí)写穴,獲取文件的名稱或者計(jì)算文件的MD5值。</p></li><li><p>將文件的名稱或者M(jìn)D5值保存在一個(gè)變量中雌贱。</p></li></ol><p>后端:</p><ol><li><p>接收到上傳請(qǐng)求時(shí)啊送,從請(qǐng)求參數(shù)或HTTP頭部中獲取文件的名稱或者M(jìn)D5值偿短。</p></li><li><p>將文件的名稱或者M(jìn)D5值與服務(wù)器上已有的文件進(jìn)行比較,判斷是否為同一文件馋没。</p></li></ol><p>注意:由于JavaScript的安全限制昔逗,無法直接在前端計(jì)算文件的MD5值。您可以選擇使用第三方庫或者調(diào)用后端API來獲取文件的MD5值篷朵。</p><p>另外纤子,如果您希望確保文件的唯一性并避免重復(fù)上傳,可以在服務(wù)器端存儲(chǔ)文件的相關(guān)信息款票,并在每次上傳前進(jìn)行檢查控硼。這樣可以避免重復(fù)上傳相同的文件。</p><p><strong>結(jié)語</strong></p><p>牽手 持續(xù)為你分享各類知識(shí)和軟件 艾少,歡迎訪問卡乾、關(guān)注、討論 并留下你的小心心?</p><p>
</p>

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末缚够,一起剝皮案震驚了整個(gè)濱河市幔妨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌谍椅,老刑警劉巖误堡,帶你破解...
    沈念sama閱讀 218,546評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異雏吭,居然都是意外死亡锁施,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門杖们,熙熙樓的掌柜王于貴愁眉苦臉地迎上來悉抵,“玉大人,你說我怎么就攤上這事摘完±咽危” “怎么了?”我有些...
    開封第一講書人閱讀 164,911評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵孝治,是天一觀的道長(zhǎng)列粪。 經(jīng)常有香客問我,道長(zhǎng)谈飒,這世上最難降的妖魔是什么岂座? 我笑而不...
    開封第一講書人閱讀 58,737評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮步绸,結(jié)果婚禮上掺逼,老公的妹妹穿的比我還像新娘吃媒。我一直安慰自己瓤介,他們只是感情好吕喘,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著刑桑,像睡著了一般氯质。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上祠斧,一...
    開封第一講書人閱讀 51,598評(píng)論 1 305
  • 那天闻察,我揣著相機(jī)與錄音,去河邊找鬼琢锋。 笑死辕漂,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的吴超。 我是一名探鬼主播钉嘹,決...
    沈念sama閱讀 40,338評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼鲸阻!你這毒婦竟也來了跋涣?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,249評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤鸟悴,失蹤者是張志新(化名)和其女友劉穎陈辱,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體细诸,經(jīng)...
    沈念sama閱讀 45,696評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沛贪,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了震贵。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鹏浅。...
    茶點(diǎn)故事閱讀 40,013評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖屏歹,靈堂內(nèi)的尸體忽然破棺而出隐砸,到底是詐尸還是另有隱情,我是刑警寧澤蝙眶,帶...
    沈念sama閱讀 35,731評(píng)論 5 346
  • 正文 年R本政府宣布季希,位于F島的核電站,受9級(jí)特大地震影響幽纷,放射性物質(zhì)發(fā)生泄漏式塌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評(píng)論 3 330
  • 文/蒙蒙 一友浸、第九天 我趴在偏房一處隱蔽的房頂上張望峰尝。 院中可真熱鬧,春花似錦收恢、人聲如沸武学。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,929評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽火窒。三九已至硼补,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間熏矿,已是汗流浹背已骇。 一陣腳步聲響...
    開封第一講書人閱讀 33,048評(píng)論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留票编,地道東北人褪储。 一個(gè)月前我還...
    沈念sama閱讀 48,203評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像慧域,于是被迫代替她去往敵國和親乱豆。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 先來個(gè)總結(jié)吊趾,我之前和將要寫到的文件上傳用到的技術(shù)和場(chǎng)景描述: 場(chǎng)景描述使用技術(shù)圖片上傳前的預(yù)覽FileReader...
    CondorHero閱讀 3,676評(píng)論 0 8
  • 前言 Google Play應(yīng)用市場(chǎng)對(duì)于應(yīng)用的targetSdkVersion有了更為嚴(yán)格的要求宛裕。從 2018 年...
    申國駿閱讀 64,222評(píng)論 14 98
  • """1.個(gè)性化消息: 將用戶的姓名存到一個(gè)變量中,并向該用戶顯示一條消息论泛。顯示的消息應(yīng)非常簡(jiǎn)單揩尸,如“Hello ...
    她即我命閱讀 2,898評(píng)論 0 5
  • 我們都是軟弱的人,所以才會(huì)說謊屁奏。我們都是膽小的人岩榆,所以才要武裝。我們都是一群笨蛋坟瓢,所以才會(huì)互相傷害勇边。
    所羅門的偽證_dc0a閱讀 2,066評(píng)論 0 3
  • 為了讓我有一個(gè)更快速、更精彩折联、更輝煌的成長(zhǎng)粒褒,我將開始這段刻骨銘心的自我蛻變之旅!從今天開始诚镰,我將每天堅(jiān)持閱...
    李薇帆閱讀 1,719評(píng)論 0 2