日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

ajax異步實現(xiàn)文件分片上傳實例代碼

瀏覽:227日期:2022-06-11 16:23:03

前言

使用Ajax上傳文件的應(yīng)用場景頗多,比如上傳用戶頭像、博客文章中插入圖片、對認證用戶相關(guān)身份進行校驗等等很多很多。這篇文章主要介紹了關(guān)于ajax異步實現(xiàn)文件分片上傳的相關(guān)內(nèi)容,下面話不多說了,來一起看看詳細的介紹吧

實例代碼:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>JS分片上傳-極速上傳</title>
</head>
<body>
 <input type="file" name="slice" id="slice" >
 
 <div id="output"><!-- 信息存放地 --> </div>
<br/>
</body>
<script src="http://libs.baidu.com/jquery/1.8.3/jquery.min.js"></script>

<script type="text/javascript">
 $("#slice").change(function(event) {
  var file = $("#slice")[0].files[0];
		var name = file.name;
				//進行初始化
				$.ajax({ 
		    type:"POST", //請求方式 
		    url:"http://localhost:8080/getuploadId",
						async: false,
		    dataType:"json", //返回數(shù)據(jù)類型
		    data:{//請求參數(shù)
		    		fileName:name,
		    },
		    success:function(data){ //請求成功后		    	
		    	console.log("data.code="+JSON.stringify(data));
							console.log("data.data.objectName="+data.data.objectName);
							console.log("data.data.uploadId="+data.data.uploadId);		
							var objectName=data.data.objectName;
							var uploadId=data.data.uploadId;
							//成功后執(zhí)行分段上傳
							PostFile(file,0,objectName,uploadId);
							//合并
							combineFile(objectName,uploadId);
							
							
						 },
		    error:function (){
		    	alert("系統(tǒng)出現(xiàn)異常!");
		    	flag=false;
		    } 
					}); 
		
  
 });
 //執(zhí)行分片上傳
 function PostFile(file,i,objectName,uploadId){
  var name = file.name,       //文件名
   size = file.size,       //總大小shardSize = 2 * 1024 * 1024,
   shardSize = 1 * 1024 * 1024,    //以2MB為一個分片,每個分片的大小
   shardCount = Math.ceil(size / shardSize); //總片數(shù)
  if(i >= shardCount){
   return;
  }
  //console.log(size,i+1,shardSize); //文件總大小,第一次,分片大小//
  var start = i * shardSize;
  var end = start + shardSize;
  var packet = file.slice(start, end); //將文件進行切片
		// 分段號
		var partNumber = i + 1;
  /* 構(gòu)建form表單進行提交 */
  var form = new FormData();
  form.append("fileId", "001")
  form.append("data", packet); //slice方法用于切出文件的一部分
//   form.append("lastModified", file.lastModified); //最后的額修改時間
  form.append("name", name);
  form.append("totalSize", size);
		
		form.append("uploadId", uploadId);
		form.append("objectName", objectName);
		form.append("mainFile", packet);
		form.append("total", shardCount);
		form.append("sortNumber", partNumber);
		
		//uploadId:uploadId,
		//objectName:objectName,
		//mainFile:blob,
		//total:partCount,
		//sortNumber:partNumber
		
  if(shardCount === i+1){
   shardSize = size - i * shardSize
  }
  form.append("shardSize", shardSize);
  form.append("total", shardCount); //總片數(shù)
  form.append("index", i + 1); //當(dāng)前是第幾片
  $.ajax({
   // header: {
   //  web_token: "cpBvqWrr0UK9zPJoKj+412alxxcY6qFwrSVoO0juZg0S1jX/sGfMd9oi3AsSxW+MdWFrwtGCykUTmMqrqpbCElmT75DfB87lENC7lCuMxgF0d5wQB6yAubUVyGOzhbrScvIfD8ZSjOJ3D88AOy2xRd4oG8TxeGoMoZqnqIwjKg="
   // },
   url: "http://localhost:8080/multipartupload",
   type: "POST",
   data: form,
   //timeout:"10000", //超時10秒
   async: false, //同步
   dataType:"json",
   processData: false, //很重要,告訴jquery不要對form進行處理
   contentType: false, //很重要,指定為false才能形成正確的Content-Type
   success: function (data) {
    console.log("data="+JSON.stringify(data));
    /* 表示上一塊文件上傳成功,繼續(xù)下一次 */
    if (data.data.code == 1) {
     form = "";
     i++;
     PostFile(file, i,objectName,uploadId);
    } else if (data.data.code == 502) {
     form = "";
     /* 失敗后,每2秒繼續(xù)傳一次分片文件 */
     setInterval(function () { PostFile(file, i,objectName,uploadId) }, 2000);
    } else if (data.data.code == 200) {
     console.log("上傳成功");
    } else if (data.data.code == 500) {
     console.log("第"+msg.i+"次,上傳文件有誤!");
    } else {
     console.log("未知錯誤");
    }
   }
  })
 }
	//合并
	function combineFile(objectName,uploadId){
			console.log("objectName="+objectName);
			console.log("uploadId="+uploadId);
			var object=new Object();
			object.objectName=objectName;
			object.uploadId=uploadId;
			 $.ajax({ 
				 
     headers: {
						Accept: "application/json; charset=utf-8"
				},
					type:"POST", //請求方式 
					url:"http://localhost:8080/combine",
					async: false,
					contentType:"application/json",
					dataType:"json", //返回數(shù)據(jù)類型
					data:JSON.stringify(object),
					success:function(data){ //請求成功后		    	
						console.log("data="+JSON.stringify(data));
						console.log("data.data.code="+data.data.code);
						console.log("data.data.url="+data.data.url);		
					},
					error:function (){
						alert("系統(tǒng)出現(xiàn)異常!");
						flag=false;
					} 
				}); 					
	
	
	}
	
</script>
</html>

總結(jié)

到此這篇關(guān)于ajax異步實現(xiàn)文件分片上傳的文章就介紹到這了,更多相關(guān)ajax異步實現(xiàn)文件分片上傳內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: Ajax
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产福利电影在线播放| 精品一区二区三区亚洲| 日韩深夜视频| 老司机精品视频网| 国产精品最新| 国产欧美一区二区色老头| 日韩精品欧美精品| 欧美一区成人| 欧美日本精品| 国产伦理一区| 日韩av不卡在线观看| 69堂精品视频在线播放| 国产精品毛片视频| 在线精品视频一区| 亚洲精品影院在线观看| 婷婷成人av| 国产精品嫩模av在线| 香蕉久久99| 欧美久久精品一级c片| 国产国产精品| 免费视频久久| 日韩欧美2区| 国产精品中文字幕制服诱惑| 国产精品va| 色网在线免费观看| 久久精品青草| 亚洲综合国产| 日韩 欧美一区二区三区| 日韩精品免费一区二区夜夜嗨| 日韩**一区毛片| 麻豆久久一区二区| 国产高潮在线| 亚洲精品电影| 日韩精品视频中文字幕| 国产欧美亚洲精品a| 精品少妇一区| 欧洲亚洲一区二区三区| 亚洲激精日韩激精欧美精品| 亚洲欧美专区| 久久三级毛片| 99久久99久久精品国产片果冰| 好看的亚洲午夜视频在线| 蜜臀久久99精品久久久久久9| 日本电影久久久| 你懂的国产精品| 日韩在线短视频| 人人精品人人爱| 国产精品久一| 欧美丝袜一区| 日日摸夜夜添夜夜添国产精品| 国内精品亚洲| 中文亚洲欧美| 久久不卡日韩美女| 国产高清一区| 国产精品中文字幕制服诱惑| 一区二区小说| 欧美片网站免费| 99久久久国产精品美女| 免费久久99精品国产自在现线| 日韩一区欧美二区| 国产一区2区在线观看| 日韩亚洲精品在线| 国产精品a久久久久| 久久蜜桃精品| 国产精品综合| 国产视频一区在线观看一区免费| 国产午夜精品一区在线观看| 亚洲播播91| 欧美日韩一区自拍| 欧洲毛片在线视频免费观看| 国产精久久久| 手机精品视频在线观看| 在线手机中文字幕| 亚洲精品在线二区| 欧美日韩尤物久久| 国产亚洲精品美女久久| 日韩视频免费| 精品久久电影| 久久一区视频| 亚洲精品第一| 91精品啪在线观看国产18| 日韩精品三级| 好吊一区二区三区| 国产资源在线观看入口av| 亚久久调教视频| 亚洲成人精品| 国产一区二区三区探花| 亚洲免费观看高清完整版在线观| 日韩高清欧美| 青青草91久久久久久久久| 亚洲高清影视| 日韩精品诱惑一区?区三区| 欧美一区精品| 亚洲综合国产| 激情偷拍久久| 国产在线看片免费视频在线观看| 国产日韩视频| 综合激情在线| 亚洲国产不卡| 久久国产精品成人免费观看的软件| 国产精品红桃| 日韩国产精品久久久久久亚洲| 日韩视频一区| 欧美精品一区二区三区精品| 黄色精品视频| 国产福利一区二区三区在线播放| 亚洲精品自拍| 鲁大师影院一区二区三区| 欧美日韩亚洲在线观看| 福利在线免费视频| 精品美女视频| 国产极品久久久久久久久波多结野 | 亚洲大全视频| 涩涩av在线| 高清久久精品| 国产一区国产二区国产三区| 国产精品白丝久久av网站| 亚洲色图国产| 视频在线观看一区二区三区| 午夜久久福利| 久久一区二区三区喷水| 日本а中文在线天堂| 国语对白精品一区二区| 国产精品v亚洲精品v日韩精品| 国产日韩欧美在线播放不卡| 日本国产欧美| 国产欧美日韩一级| 国产免费久久| 欧美激情精品| 久久人人精品| 久久精品影视| 欧美福利一区| 国产欧美日韩一级| 美女视频黄久久| 国语对白精品一区二区| 伊人网在线播放| 九色精品91| 亚洲欧美专区| 国产精品分类| 国产欧洲在线| 欧美精选视频一区二区| 九一成人免费视频| 水野朝阳av一区二区三区| 免费看黄色91| 日韩高清二区| 久久福利在线| 欧美日韩免费看片| 91精品一区二区三区综合| 欧美日韩国产高清| 中文字幕视频精品一区二区三区| 欧美一级二级三级视频| 国产一区二区视频在线看| 久久精品观看| av成人国产| 免费一区二区视频| 日韩在线电影| 精品亚洲二区| 国产一区不卡| aa国产精品| 亚洲三级精品| 国产欧美日韩精品一区二区免费 | 免费在线观看一区二区三区| 快she精品国产999| 亚洲午夜国产成人| 中文字幕一区二区av| 国产精品毛片aⅴ一区二区三区| 国产精品男女| 日产精品一区二区| 欧美日韩尤物久久| 欧美日韩激情| 免费人成在线不卡| 91成人在线网站| 国产福利资源一区| 在线一区视频观看| 欧美日韩少妇| 蜜桃视频一区二区三区在线观看| 亚欧洲精品视频在线观看| 国产伦精品一区二区三区千人斩 | 尹人成人综合网| 一二三区精品| 国产伦乱精品| 天堂а√在线最新版中文在线| 三级欧美韩日大片在线看| 日韩中文字幕一区二区高清99| 欧美在线黄色| 欧美xxxx性| 欧美日韩国产免费观看视频| 国产探花在线精品一区二区| 国产不卡人人| 黑丝一区二区| 欧美在线91| 天堂久久av| 婷婷激情一区| 久久亚洲国产精品一区二区| 日韩和欧美一区二区三区| 成人污污视频| 午夜免费一区| 国产日韩欧美一区二区三区| 日韩一区三区| 久久国产精品亚洲77777|