久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

h5在網頁中上傳超大文件教程實例

利用HTML5分片上傳超大文件

在網頁中直接上傳大文件一直是個比較頭疼的問題,主要面臨的問題一般包括兩類:一是上傳時間長中途一旦出錯會導致前功盡棄;二是服務端配置復雜,要考慮接收超大表單和超時問題,如果是托管主機沒準還改不了配置,默認只能接收小于4MB的附件。

比較理想的方案是能夠把大文件分片,一片一片的傳到服務端,再由服務端合并。這么做的好處在于一旦上傳失敗只是損失一個分片而已,不用整個文件重傳,而且每個分片的大小可以控制在4MB以內,服務端不用做任何設置就可適應。

常用的解決方案是RIA,以flex為例,通常是利用FileReference.load方法加載文件得到ByteArray,然后分片構造表單(flash的高版本不允許直接訪問文件)。不過這個load方法只能加載較小的文件,大約不超過300MB,因此適用性不是很強。

好在現在有了HTML5,我們可以直接構造分片了,這是一個非常喜人的進步,只可惜目前適用面不廣(IE啊IE,真是恨你恨得牙癢癢)。

言歸正傳,來看一個DEMO吧,基于ASP.Net MVC3,只是示例,很多問題做了簡化處理。

主要是客戶端,新特性都體現在這里:

<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<dynamic>" %>  <!DOCTYPE html>  <html lang="zh-CN">  <head>      <meta charset="utf-8">      <title>HTML5大文件分片上傳示例</title>      <script src="../Scripts/jquery-1.11.1.min.js"></script>      <script>      var page = {          init: function(){              $("#upload").click($.proxy(this.upload, this));          },                   upload: function(){              var file = $("#file")[0].files[0],  //文件對象                  name = file.name,        //文件名                  size = file.size,        //總大小                  succeed = 0;                                 var shardSize = 2 * 1024 * 1024,    //以2MB為一個分片                  shardCount = Math.ceil(size / shardSize);  //總片數                                 for(var i = 0;i < shardCount;++i){                  //計算每一片的起始與結束位置                  var start = i * shardSize,                      end = Math.min(size, start + shardSize);                  //構造一個表單,FormData是HTML5新增的                  var form = new FormData();                  form.append("data", file.slice(start,end));  //slice方法用于切出文件的一部分                  form.append("name", name);                  form.append("total", shardCount);  //總片數                  form.append("index", i + 1);        //當前是第幾片                                   //Ajax提交                  $.ajax({                      url: "../File/Upload",                      type: "POST",                      data: form,                      async: true,        //異步                      processData: false,  //很重要,告訴jquery不要對form進行處理                      contentType: false,  //很重要,指定為false才能形成正確的Content-Type                      success: function(){                          ++succeed;                          $("#output").text(succeed + " / " + shardCount);                      }                  });              }          }      };      $(function(){          page.init();      });      </script>  </head>  <body>      <input type="file" id="file" />      <button id="upload">上傳</button>      <span id="output" style="font-size:12px">等待</span>  </body>  </html>

這里的slice方法和FormData都是html5之前不存在的。通過這樣的方法,我們的表單構造出來是這樣的,抓包看看:

h5在網頁中上傳超大文件教程實例

可以看到構造出來的Content-Type是multipart/form-data,也就是符合RFC標準的那個最傳統的文件上傳表單。另外我們同時傳輸的name、total等屬性也都在表單里。

然后是服務端,沒什么新鮮的,完全是在接收一個普通的文件:

[HttpPost]  public ActionResult Upload()  {      //從Request中取參數,注意上傳的文件在Requst.Files中      string name = Request["name"];      int total = Convert.ToInt32(Request["total"]);      int index = Convert.ToInt32(Request["index"]);      var data = Request.Files["data"];           //保存一個分片到磁盤上      string dir = Server.MapPath("~/Upload");      string file = Path.Combine(dir, name + "_" + index);      data.SaveAs(file);           //如果已經是最后一個分片,組合      //當然你也可以用其它方法比如接收每個分片時直接寫到最終文件的相應位置上,但要控制好并發防止文件鎖沖突      if(index == total)      {          file = Path.Combine(dir, name);          var fs = new FileStream(file, FileMode.Create);          for(int i = 1;i <= total;++i)          {              string part = Path.Combine(dir, name + "_" + i);              var bytes = System.IO.File.ReadAllBytes(part);              fs.Write(bytes, 0, bytes.Length);              bytes = null;              System.IO.File.Delete(part);          }          fs.Close();      }           //返回是否成功,此處做了簡化處理      return Json(new { Error = 0 });  }

上面的DEMO很多問題是簡化處理的,比如沒做什么異常處理,客戶端也沒有判斷服務端是否出錯重試一類的,各位可以自己完善。

在上面的基礎上,我們可以做很多功能上的擴展,比如我們可以控制所有分片是順序上傳還是并發上傳,以適用不同應用。再比如我們可以在整體文件上傳前以及分片上傳前都先計算一下相應的HASH,發個請求詢問服務器文件是否已存在,如果存在就不要重復上傳了,這樣就實現了“極速上傳”以及“斷點續傳”

【相關推薦】

1. 免費h5在線視頻教程

2. HTML5 完整版手冊

3. php.cn原創html5視頻教程

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
久久国产毛片| 在线成人直播| 日韩亚洲精品在线观看| 午夜在线一区二区| 亚洲专区欧美专区| 亚洲欧美日韩精品一区二区 | 免费视频最近日韩| 国产精品美女久久久| 麻豆亚洲精品| 亚洲日本三级| 欧美亚洲自偷自偷| 国产精品嫩草影院在线看| 久久国内精品| 精品国产欧美日韩一区二区三区| 精品国产精品久久一区免费式| 精品国产亚洲一区二区三区大结局| 久久精品国产99国产精品| 国产精品多人| 午夜av不卡| 九色精品91| 视频一区视频二区中文| 四虎成人精品一区二区免费网站| 久久精品99国产精品| 久久亚州av| 999精品色在线播放| 久久国产精品毛片| 国产欧美日韩影院| 欧美国产中文高清| 视频福利一区| 喷白浆一区二区| 国产精品毛片aⅴ一区二区三区| 久久精品女人| 日韩精品免费一区二区三区| 国产亚洲精品自拍| 国产精品夜夜夜| 五月天av在线| 中文字幕一区二区三区日韩精品| 欧美亚洲一区二区三区| 伊人久久av| 免费在线观看日韩欧美| 国产精品一线天粉嫩av| 在线一区视频观看| 999国产精品永久免费视频app| 首页欧美精品中文字幕| 你懂的亚洲视频| 激情五月色综合国产精品| 日韩欧美三区| 日韩欧美视频专区| 亚洲a成人v| 亚洲综合在线电影| 视频精品一区| 亚洲人成在线网站| 日韩精品一页| 99久久久久久中文字幕一区| 欧美偷窥清纯综合图区| 久久久一二三| 国产日产一区| 欧美丝袜一区| 国产精品尤物| 狠狠色狠狠色综合日日tαg| 国产精品红桃| 丝袜诱惑制服诱惑色一区在线观看 | 国产日韩电影| 一区二区电影在线观看| 麻豆理论在线观看| 亚洲精品一二| 精品国产亚洲一区二区三区在线 | 五月天激情综合网| 亚洲精品综合| 免播放器亚洲一区| 久久久久久色 | 亚洲v天堂v手机在线| 好吊日精品视频| 中文无码久久精品| 亚洲精品四区| 国产一精品一av一免费爽爽| 亚洲欧美日韩视频二区| 亚洲日本欧美| 亚洲一区二区动漫| 日韩和欧美一区二区| 国产一区二区三区久久| 伊人影院久久| 久久亚洲人体| 日韩激情一区二区| 激情综合自拍| 成人日韩av| 国产精品一站二站| 中文字幕日本一区| 中文精品视频| 日本在线精品| 国产成人精选| 免费在线观看一区| 日韩av中文字幕一区二区三区| aa亚洲婷婷| 久久精品123| 色综合狠狠操| 国产精品xvideos88| 亚洲制服一区| 黄色亚洲精品| 久久精品国产大片免费观看| 福利一区和二区| 国产精品调教| 日韩国产欧美三级| 亚洲丝袜美腿一区| 国产精品嫩草99av在线| 欧美va天堂| 91精品国产福利在线观看麻豆| 麻豆免费精品视频| 国产日韩精品视频一区二区三区| 亚洲一二av| 日韩中文字幕亚洲一区二区va在线 | 亚洲天堂免费| 99视频在线精品国自产拍免费观看| 黑人精品一区| 成人影视亚洲图片在线| 里番精品3d一二三区| 国产免费av国片精品草莓男男| 亚洲综合专区| 亚洲综合色婷婷在线观看| 91精品综合| 日韩欧美一区二区三区免费观看| 日韩1区2区| 在线中文字幕播放| 久久电影tv| 欧美成a人免费观看久久| 日本欧美不卡| 激情自拍一区| 亚洲欧美日韩国产一区| 丝袜亚洲精品中文字幕一区| 亚洲一区二区免费在线观看| 亚洲三级网站| 日韩综合一区二区| 日本不卡不码高清免费观看| 最新国产精品视频| 亚洲一区二区毛片| 天堂成人国产精品一区| 美国三级日本三级久久99 | 日韩国产在线观看一区| 欧美日韩亚洲三区| 国产精品伊人| 国产在线观看91一区二区三区| 麻豆精品在线播放| 日韩成人a**站| 久久精品国产www456c0m| 最新日韩欧美| 亚洲精品欧美| 国产精品二区影院| 精品日产乱码久久久久久仙踪林| 欧美国产一级| 1000部精品久久久久久久久| 亚州av乱码久久精品蜜桃| 亚洲专区在线| 日本99精品| 久久免费精品| 久久要要av| 天堂va蜜桃一区二区三区| 日本亚洲欧美天堂免费| 亚洲一区网站| 青青草精品视频| 国产成人精品亚洲线观看| 久久网站免费观看| 免费人成精品欧美精品| 日韩**一区毛片| 麻豆精品久久| 蜜桃成人av| 天堂va欧美ⅴa亚洲va一国产| 麻豆一区二区三| 日韩精品午夜| 日韩精品免费视频人成| 成人日韩av| 蜜乳av另类精品一区二区| 国产日韩精品视频一区二区三区| 日韩大片在线观看| 丝袜美腿高跟呻吟高潮一区| 免费在线日韩av| 99国产精品久久久久久久| 欧美日韩亚洲一区三区| 国产精品伦理久久久久久| 影音国产精品| 国产精品天堂蜜av在线播放| 国产综合色区在线观看| 首页国产欧美日韩丝袜| 精品视频久久| 中文字幕成人| 久久蜜桃精品| 欧美亚洲综合视频| 欧美日韩视频网站| 免费在线观看一区二区三区| 精品在线网站观看| 在线视频免费在线观看一区二区| 国产欧美一区二区三区国产幕精品 | 日韩中文字幕一区二区高清99| 久久福利在线| 欧美1级日本1级| 欧美国产精品| 在线亚洲国产精品网站| 久久一区欧美| 亚洲精品黄色| av最新在线| 日本欧美大码aⅴ在线播放|