HTML
<form method="POST" name="form" action="/mupload/upload/" enctype="multipart/form-data"> <input type='hidden' name='csrfmiddlewaretoken' value='' /> <input id='file' type='file' name='file' onchange="" /> <input id='button' name='submit' type='button' value="上传" onclick="chunk_upload(this)"/> </form>
js 메소드
var fileSplitSize = 1024 * 1024; var start=0,end=0; var i=0; // 文件段上传 function chunk_upload(button){ var xmlhttp = new XMLHttpRequest(); xmlhttp.open("POST", "/chunk_upload/upload/", false); xmlhttp.setRequestHeader("X-CSRFToken", button.form['csrfmiddlewaretoken'].value); var f = button.form; var file = f['file']['files'][0]; var size=file.size; end=start+fileSplitSize; if(end>size){ i=-1; end=size; }else{ i+=1; end=end; }<br> //按大小切割文件段 var blob = file.slice(start, end); xmlhttp.setRequestHeader('charset','utf-8'); xmlhttp.setRequestHeader("fileMD5", fileMD5); xmlhttp.setRequestHeader("start", start); xmlhttp.setRequestHeader("end", end); xmlhttp.send(blob); if(xmlhttp.status==200){<br> if(end==size){<br> var backtext=xmlhttp.responseText;<br> alert(backtext);<br> }else{<br> alert("上传完成第"+i+"段")<br> start=end;<br> chunk_upload(button);<br> }<br> }else{<br> alert("上传错误");<br> chunk_upload(button);<br> } }
주요 아이디어:
자르기 시작 위치와 자르기 크기 설정에 주의하고 XMLHttpRequest를 통해 요청을 보냅니다(http 프로토콜을 알아야 함).
마크업 데이터가 있는 경우 프로토콜 헤더를 추가할 수 있습니다: xmlhttp.setRequestHeader("end", end);
프로토콜 본문 보내기 xmlhttp.send(data);
반환 코드를 모니터링하여 전송 성공 여부를 확인하고 다음 단계로 진행하세요.
자르기 위치를 재설정한 다음 재귀적으로 start=end;chunk_upload(button);
을 호출합니다.
참고:
자르기 시작, 끝, 파일 크기의 관계
Pure js는 비동기적으로 파일을 업로드하고 업로드 진행 상황을 반환합니다
Pure JS는 비동기식 파일 업로드를 구현하고, 파일 업로드 진행 상황을 비동기적으로 반환하며, 0.05~0.1초마다 한 번씩 업로드 진행 상황을 콜백합니다. 기타 자세한 내용은 코드 스니펫 아래의 사용 참고 사항을 참조하세요.
1. 간단한 비동기 업로드 기능
;(function(window,document){ var myUpload = function(option) { var file, fd = new FormData(), xhr = new XMLHttpRequest(), loaded, tot, per, uploadUrl,input; input = document.createElement("input"); input.setAttribute('id',"myUpload-input"); input.setAttribute('type',"file"); input.setAttribute('name',"files"); input.click(); uploadUrl = option.uploadUrl; callback = option.callback; uploading = option.uploading; beforeSend = option.beforeSend; input.onchange= function(){ file = input.files[0]; if(beforeSend instanceof Function){ if(beforeSend(file) === false){ return false; } } fd.append("files", file); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { if(callback instanceof Function){ callback(xhr.responseText); } } } //侦查当前附件上传情况 xhr.upload.onprogress = function(evt) { loaded = evt.loaded; tot = evt.total; per = Math.floor(100 * loaded / tot); //已经上传的百分比 if(uploading instanceof Function){ uploading(per); } }; xhr.open("post", uploadUrl); xhr.send(fd); } }; window.myUpload = myUpload; })(window,document); //用法 //触发文件上传事件 myUpload({ //上传文件接收地址 uploadUrl: "/async/myUpload.php", //选择文件后,发送文件前自定义事件 //file为上传的文件信息,可在此处做文件检测、初始化进度条等动作 beforeSend: function(file) { }, //文件上传完成后回调函数 //res为文件上传信息 callback: function(res) { }, //返回上传过程中包括上传进度的相关信息 //详细请看res,可在此加入进度条相关代码 uploading: function(res) { } });