{"id":410,"date":"2022-04-27T10:51:54","date_gmt":"2022-04-27T02:51:54","guid":{"rendered":"http:\/\/gjweb.top\/?p=410"},"modified":"2024-02-27T10:06:13","modified_gmt":"2024-02-27T02:06:13","slug":"%e5%bd%bb%e5%ba%95%e6%90%9e%e6%87%82%e6%96%87%e4%bb%b6%e4%b8%8a%e4%bc%a0","status":"publish","type":"post","link":"https:\/\/gjweb.top\/?p=410","title":{"rendered":"\u5f7b\u5e95\u641e\u61c2\u6587\u4ef6\u4e0a\u4f20\u5e26\u5b8c\u6574\u5b9e\u73b0\u8fc7\u7a0b"},"content":{"rendered":"\n<p>\u4f20\u7edf\u539f\u751f\u8868\u5355\u4e0a\u4f20\u6837\u5f0f\u5df2\u7ecf\u4e0d\u6ee1\u8db3\u73b0\u5728\u524d\u7aef\u53d1\u5c55\u7684\u9700\u6c42\uff0c\u73b0\u5728\u5e02\u573a\u901a\u5e38\u91c7\u7528\u5404\u79cd\u7b2c\u4e09\u65b9UI\u7ec4\u4ef6\u5e93\u6ee1\u8db3\u65e5\u5e38\u6240\u9700\u3002\u4f46\u5728\u5f00\u53d1\u4e2d\u5305\u62ec\u6211\u5728\u5185\u7684\u4e0d\u5c11\u5f00\u53d1\u8005\u77e5\u5176\u7136\u5374\u4e0d\u77e5\u5176\u6240\u4ee5\u7136\uff0c\u8fd9\u7bc7\u6587\u7ae0\u8ba9\u6211\u4eec\u5f7b\u5e95\u641e\u61c2\u6587\u4ef6\u4e0a\u4f20\u7684\u5404\u4e2a\u573a\u666f<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u5355\u4e00\u6587\u4ef6\u4e0a\u4f20\">\u5355\u4e00\u6587\u4ef6\u4e0a\u4f20<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u601d\u8def\">\u5b9e\u73b0\u601d\u8def<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5b9e\u73b0\u4e0a\u4f20\u529f\u80fd\u4ecd\u7136\u9700\u8981\u501f\u52a9 input \u7684 file \u5c5e\u6027\uff0c\u5e76\u9690\u85cf\u9690\u85cf\u5143\u7d20<\/li>\n\n\n\n<li>\u4f7f\u7528 js \u624b\u52a8\u89e6\u53d1 input \u4e8b\u4ef6<\/li>\n\n\n\n<li>\u7528 html \u5143\u7d20\u4f18\u5316\u4ee3\u66ff\u539f\u751f\u7684 input \u7684\u6837\u5f0f<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u4f18\u5316\u7ed3\u679c\">\u4f18\u5316\u7ed3\u679c<\/h3>\n\n\n\n<figure class=\"wp-block-image\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650950932(1).png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650950932(1).png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\"\/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u4ee3\u7801\">\u5b9e\u73b0\u4ee3\u7801<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"html\">html<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code> &nbsp;&lt;div class=\"container\"&gt;<br> &nbsp; &nbsp;&lt;div class=\"buttonContainer\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;input type=\"file\" id=\"inputInput\" style=\"display:none\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-select button\"&gt;\u9009\u62e9\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-submit button\"&gt;\u4e0a\u4f20\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div&gt;\u6587\u4ef6\u4ec5\u652f\u6301png\u683c\u5f0f\u7684\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;ul id=\"list\"&gt;&lt;\/ul&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp;&lt;\/div&gt;<\/code><\/pre>\n\n\n\n<p>HTML \u90e8\u5206\u7684\u6837\u5f0f\u5185\u5bb9\u5ffd\u7565\uff0c\u4f46\u5176\u4e2d\u7684\u6280\u672f\u70b9\u5728\u4e8e <strong>\u9690\u85cf\u4e86 input \u5143\u7d20<\/strong> \uff0c\u7528 div \u6a21\u62df\u4e86\u9009\u62e9\u6587\u4ef6\u548c\u4e0a\u4f20\u6587\u4ef6\u6309\u94ae<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"javascript\">javaScript<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code>let inputInput = document.querySelector(\"#inputInput\")<br>let select = document.querySelector(\".button-select\")<br>let submit = document.querySelector(\".button-submit\")<br>let list = document.querySelector(\"#list\")<br>let filesData;<br>\u200b<br>\/\/ \u83b7\u53d6\u672c\u5730\u6587\u4ef6<br>inputInput.onchange=()=&gt;{<br> &nbsp;let files = inputInput.files&#91;0]<br> &nbsp;console.log(files)<br> &nbsp;if(files.type !== \"image\/png\"){<br> &nbsp; &nbsp;alert(\"\u6587\u4ef6\u53ea\u652f\u6301png\u683c\u5f0f\")<br> &nbsp; &nbsp;return<br>  } <br> &nbsp;if(files.size&gt;2*1024*1024){<br> &nbsp; &nbsp;alert(\"\u6587\u4ef6\u6700\u5927\u652f\u63012MB\")<br> &nbsp; &nbsp;return<br>  }<br> &nbsp;filesData = files<br> &nbsp;list.innerHTML = `<br> &nbsp; &nbsp;&lt;li&gt;${files.name} &lt;span class=\"del\"&gt;\u79fb\u9664&lt;\/span&gt;&lt;\/li&gt;<br> &nbsp;`<br>}<br>\/\/ \u65f6\u95f4\u59d4\u6258<br>list.onclick = (event)=&gt;{<br> &nbsp;if(event.target.innerHTML === \"\u79fb\u9664\"){<br> &nbsp; &nbsp;list.innerHTML = \"\";<br> &nbsp; &nbsp;filesData = null<br>  }<br>}<br>\/\/ \u89e6\u53d1\u4e0a\u4f20\u7684click\u4e8b\u4ef6<br>select.onclick = ()=&gt;{<br> &nbsp;inputInput.click()<br>}<br>\/\/ \u63d0\u4ea4<br>submit.onclick = ()=&gt;{<br> &nbsp;if(filesData){<br> &nbsp; &nbsp;let formData = new FormData();<br> &nbsp; &nbsp;formData.append(\"files\",filesData)<br> &nbsp; &nbsp;fetch(\"www.baidu.com\",{<br> &nbsp; &nbsp; &nbsp;method:\"POST\",<br> &nbsp; &nbsp; &nbsp;body:formData<br> &nbsp;  }).then((response)=&gt;{<br> &nbsp; &nbsp; &nbsp;console.log(response)<br> &nbsp;  })<br>  }<br>}<\/code><\/pre>\n\n\n\n<p>\u4e0a\u9762\u7684 javascript \u4ee3\u7801\uff0c \u83b7\u53d6\u201c\u9009\u62e9\u6587\u4ef6\u201d select \uff0c\u5728 select \u70b9\u51fb\u7684\u65f6\u5019\u89e6\u53d1 input \u7684\u70b9\u51fb\u4e8b\u4ef6\uff0c\u5f39\u51fa\u6587\u4ef6\u9009\u62e9\u5668\uff1b \u7ed1\u5b9a input \u7684 change \u4e8b\u4ef6 \u76d1\u542c\u9009\u4e2d\u7684\u6587\u4ef6\u5bf9\u8c61\uff0c \u901a\u8fc7 files \u5c5e\u6027\u83b7\u53d6\u5bf9\u8c61\u5168\u90e8\u4fe1\u606f\u5e76\u4f5c\u76f8\u5e94\u7684\u4e1a\u52a1\u5224\u65ad\uff0c\u6bd4\u5982 \u6587\u4ef6\u7c7b\u578b\u3001\u6587\u4ef6\u5927\u5c0f\u3001\u6587\u4ef6\u4e0a\u4f20\u5217\u8868\u7b49\u3002\u901a\u8fc7\u70b9\u51fb submit \u5143\u7d20\u624b\u52a8\u521b\u5efa formData \u5b9e\u4f8b \u5c06\u6587\u4ef6\u5143\u7d20\u6dfb\u52a0\u8fdb\u53bb\uff0c\u4f20\u7ed9\u540e\u7aef<\/p>\n\n\n\n<hr class=\"wp-block-separator has-css-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u5355\u4e00\u6587\u4ef6\u4e0a\u4f20base64\">\u5355\u4e00\u6587\u4ef6\u4e0a\u4f20BASE64<\/h2>\n\n\n\n<p>\u5355\u4e00\u6587\u4ef6\u4e0a\u4f20\u5c06\u6587\u4ef6\u8f6c\u4e3a base64\u7f16\u7801 \uff0c \u4e3b\u8981\u501f\u52a9 FileReader \u5b9e\u4f8b\u5bf9\u8c61\uff0c\u8be5\u5bf9\u8c61\u4e0d\u4ec5\u53ef\u4ee5\u8f6c\u5316\u4e3a base64\uff0c\u8fd8\u652f\u6301 readAsArrayBuffer \u7684\u8f6c\u6362\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u7ed3\u679c\">\u5b9e\u73b0\u7ed3\u679c<\/h3>\n\n\n\n<figure class=\"wp-block-image\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650952479(1).png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650952479(1).png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\"\/><\/div><\/figure>\n\n\n\n<p>\u4ee5\u4e0a\u4ee3\u7801\u7684\u5b9e\u73b0\u5f62\u5f0f\uff0c\u70b9\u51fb \u9009\u62e9\u6587\u4ef6 \u6309\u94ae\uff0c\u9009\u62e9\u6587\u4ef6\u540e\u81ea\u52a8\u4e0a\u4f20\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u65b9\u5f0f\">\u5b9e\u73b0\u65b9\u5f0f<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"html\">html<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code> &nbsp;&lt;div class=\"container\"&gt;<br> &nbsp; &nbsp;&lt;div class=\"buttonContainer\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;input type=\"file\" id=\"inputInput\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-select button\"&gt;\u9009\u62e9\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div&gt;\u6587\u4ef6\u4ec5\u652f\u6301png\u683c\u5f0f\u7684\u6587\u4ef6&lt;\/div&gt;<br> &nbsp;&lt;\/div&gt;<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"javascript\">javascript<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code>let inputInput = document.querySelector(\"#inputInput\")<br>let select = document.querySelector(\".button-select\")<br>\u200b<br>let fileReader =(files)=&gt;{ <br> &nbsp;return new Promise((resolve,reject)=&gt;{<br> &nbsp; &nbsp;let fileReader = new FileReader();<br> &nbsp; &nbsp;fileReader.readAsDataURL(files)<br> &nbsp; &nbsp;fileReader.onload=(event)=&gt;{<br> &nbsp; &nbsp; &nbsp;resolve(event.target.result)<br> &nbsp;  }<br>  })<br>}<br>\/\/ \u83b7\u53d6\u672c\u5730\u6587\u4ef6<br>inputInput.onchange=async ()=&gt;{<br> &nbsp;let files = inputInput.files&#91;0]<br> &nbsp;if(files.size&gt;2*1024*1024){<br> &nbsp; &nbsp;alert(\"\u6587\u4ef6\u6700\u5927\u652f\u63012MB\")<br> &nbsp; &nbsp;return<br>  }<br> &nbsp;let base64 = await fileReader(files)<br> &nbsp;fetch(\"http:\/\/www.baidu.com\",{<br> &nbsp; &nbsp;method:\"POST\",<br> &nbsp; &nbsp;headers:{<br> &nbsp; &nbsp; &nbsp;'Content-Type': 'application\/x-www-form-urlencoded'<br> &nbsp;  },<br> &nbsp; &nbsp;body:JSON.stringify({<br> &nbsp; &nbsp; &nbsp;files:base64,<br> &nbsp; &nbsp; &nbsp;filesName:files.name<br> &nbsp;  })<br>  })<br>}<br>\/\/ \u89e6\u53d1\u4e0a\u4f20\u7684click\u4e8b\u4ef6<br>select.onclick = ()=&gt;{<br> &nbsp;inputInput.click()<br>}<\/code><\/pre>\n\n\n\n<p>\u5b9e\u73b0\u81ea\u52a8\u4e0a\u4f20\u7684\u903b\u8f91\uff0c\u4e3b\u8981\u662f\u76d1\u542c input file \u7684 change \u4e8b\u4ef6\uff0c\u5728 change \u4e8b\u4ef6\u4e2d\u76f4\u63a5\u5904\u7406\u56fe\u7247\u4e3a base64 \u7f16\u7801\uff0c\u7136\u540e\u8bf7\u6c42\u540e\u53f0\u63a5\u53e3\u3002<\/p>\n\n\n\n<p>\u503c\u5f97\u6ce8\u610f\u7684\u662f FileReader \u7684\u5b9e\u4f8b\u4e3a\u5f02\u6b65\u65b9\u6cd5\uff0c\u6240\u4ee5\u4e0a\u9762\u4ee3\u7801\u5bf9 FileReacer \u505a\u4e86 Promise \u7684\u5c01\u88c5\uff0c\u81f3\u4e8e\u4e0d\u4e86\u89e3 Promise \u7684\u5c0f\u4f19\u4f34\u8bf7\u81ea\u884c\u767e\u5ea6\u77e5\u8bc6\u76f2\u533a\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-css-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u6587\u4ef6\u4e0a\u4f20\u7f29\u7565\u56fe\">\u6587\u4ef6\u4e0a\u4f20\u7f29\u7565\u56fe<\/h2>\n\n\n\n<p>\u501f\u52a9 base64 \u7f16\u7801 \u5b9e\u73b0\u6587\u4ef6\u7f29\u7565\u56fe\u6548\u679c<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u7ed3\u679c\">\u5b9e\u73b0\u7ed3\u679c<\/h3>\n\n\n\n<figure class=\"wp-block-image\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650952842(1).png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650952842(1).png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\"\/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u903b\u8f91\">\u5b9e\u73b0\u903b\u8f91<\/h3>\n\n\n\n<p>\u5c06\u6587\u4ef6 \u7f16\u7801\u4e3abase64\uff0c\u590d\u5236\u7ed9 img \u5143\u7d20<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"html\">html<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code> &nbsp;&lt;div class=\"container\"&gt;<br> &nbsp; &nbsp;&lt;div class=\"buttonContainer\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;input type=\"file\" id=\"inputInput\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-select button\"&gt;\u9009\u62e9\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-submit button\"&gt;\u4e0a\u4f20\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;img src=\"\" alt=\"\" id=\"img\"&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp;&lt;\/div&gt;<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"javascript\">javascript<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code>let inputInput = document.querySelector(\"#inputInput\")<br>let select = document.querySelector(\".button-select\")<br>let submit = document.querySelector(\".button-submit\")<br>let img = document.querySelector(\"#img\")<br>let filesData;<br>\u200b<br>\/\/ \u5c06\u6587\u4ef6\u8f6c\u6210base64<br>const toBase64 = (files)=&gt;{<br> &nbsp;return new Promise((resolve,reject)=&gt;{<br> &nbsp; &nbsp;let fileReader = new FileReader();<br> &nbsp; &nbsp;fileReader.readAsDataURL(files)<br> &nbsp; &nbsp;fileReader.onload=(event)=&gt;{<br> &nbsp; &nbsp; &nbsp;resolve(event.target.result)<br> &nbsp;  }<br>  })<br>}<br>\u200b<br>\/\/ \u83b7\u53d6\u672c\u5730\u6587\u4ef6<br>inputInput.onchange=async ()=&gt;{<br> &nbsp;let files = inputInput.files&#91;0]<br> &nbsp;console.log(files)<br> &nbsp;if(files.size&gt;2*1024*1024){<br> &nbsp; &nbsp;alert(\"\u6587\u4ef6\u6700\u5927\u652f\u63012MB\")<br> &nbsp; &nbsp;return<br>  }<br> &nbsp;filesData = files;<br> &nbsp;let base64 = await toBase64(files);<br> &nbsp;console.log(\"base64\",base64)<br> &nbsp;img.src = base64<br>}<br>\/\/ \u89e6\u53d1\u4e0a\u4f20\u7684click\u4e8b\u4ef6<br>select.onclick = ()=&gt;{<br> &nbsp;inputInput.click()<br>}<br>\/\/ \u63d0\u4ea4<br>submit.onclick = ()=&gt;{<br> &nbsp;if(filesData){<br> &nbsp; &nbsp;let formData = new FormData();<br> &nbsp; &nbsp;formData.append(\"files\",filesData)<br> &nbsp; &nbsp;fetch(\"www.baidu.com\",{<br> &nbsp; &nbsp; &nbsp;method:\"POST\",<br> &nbsp; &nbsp; &nbsp;body:formData<br> &nbsp;  }).then((response)=&gt;{<br> &nbsp; &nbsp; &nbsp;console.log(response)<br> &nbsp;  })<br>  }<br>}<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-css-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u6587\u4ef6\u4e0a\u4f20\u8fdb\u5ea6\u7ba1\u63a7\">\u6587\u4ef6\u4e0a\u4f20\u8fdb\u5ea6\u7ba1\u63a7<\/h2>\n\n\n\n<p>\u4f7f\u7528 axios \u6216\u8005 \u539f\u751f XHR \u53d1\u8d77\u63a5\u53e3\u8bf7\u6c42\uff0c\u5176\u4e2d\u8fd9\u4e24\u4e2a\u5b9e\u4f8b\u4e2d\u63d0\u4f9b\u4e86 onUploadProgress \u5c5e\u6027\uff0c onUploadProgress \u4e3a\u4e00\u4e2a\u56de\u8c03\u51fd\u6570\uff0c\u76d1\u542c\u4e0a\u4f20\u72b6\u6001 \u5176\u4e2d loaded \u4e3a\u5f53\u524d\u4e0a\u4f20\u7684\u6570\u91cf\uff0ctotal \u4e3a\u6587\u4ef6\u603b\u91cf\u3002<\/p>\n\n\n\n<p>\u503c\u5f97\u6ce8\u610f\u7684\u662f\u65b0\u7684 fetch \u8bf7\u6c42\u65b9\u5f0f\uff0c\u65e0\u6cd5\u76d1\u542c\u6587\u4ef6\u4e0a\u4f20\u548c\u4e0b\u8f7d\u8fdb\u5ea6\u72b6\u6001<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u7ed3\u679c\">\u5b9e\u73b0\u7ed3\u679c<\/h3>\n\n\n\n<figure class=\"wp-block-image\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650953031(1).png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650953031(1).png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\"\/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u65b9\u5f0f\">\u5b9e\u73b0\u65b9\u5f0f<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"html\">html<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code> &nbsp;&lt;div class=\"container\"&gt;<br> &nbsp; &nbsp;&lt;div class=\"buttonContainer\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;input type=\"file\" id=\"inputInput\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-select button\"&gt;\u9009\u62e9\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-submit button\"&gt;\u4e0a\u4f20\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div&gt;\u6587\u4ef6\u4ec5\u652f\u6301png\u683c\u5f0f\u7684\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div class=\"progress\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"progressBar\" style=\"width: 10%;\"&gt;&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp;&lt;\/div&gt;<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"javascript\">javascript<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code>let inputInput = document.querySelector(\"#inputInput\")<br>let select = document.querySelector(\".button-select\")<br>let submit = document.querySelector(\".button-submit\")<br>let progressBar = document.querySelector(\".progressBar\")<br>let filesData;<br>\u200b<br>\u200b<br>\/\/ \u83b7\u53d6\u672c\u5730\u6587\u4ef6<br>inputInput.onchange=()=&gt;{<br> &nbsp;let files = inputInput.files&#91;0]<br> &nbsp;console.log(files)<br> &nbsp;if(files.type !== \"text\/plain\"){<br> &nbsp; &nbsp;alert(\"\u6587\u4ef6\u53ea\u652f\u6301text\u683c\u5f0f\")<br> &nbsp; &nbsp;return<br>  } <br> &nbsp;if(files.size&gt;2*1024*1024){<br> &nbsp; &nbsp;alert(\"\u6587\u4ef6\u6700\u5927\u652f\u63012MB\")<br> &nbsp; &nbsp;return<br>  }<br> &nbsp;filesData = files<br>}<br>\/\/ \u89e6\u53d1\u4e0a\u4f20\u7684click\u4e8b\u4ef6<br>select.onclick = ()=&gt;{<br> &nbsp;inputInput.click()<br>}<br>\/\/ \u63d0\u4ea4<br>submit.onclick = ()=&gt;{<br> &nbsp;if(filesData){<br> &nbsp; &nbsp;let formData = new FormData();<br> &nbsp; &nbsp;formData.append(\"files\",filesData)<br> &nbsp; &nbsp;axios({<br> &nbsp; &nbsp; &nbsp;method:\"POST\",<br> &nbsp; &nbsp; &nbsp;url:\"https:\/\/jsonplaceholder.typicode.com\/posts\/\",<br> &nbsp; &nbsp; &nbsp;data:formData,<br> &nbsp; &nbsp; &nbsp;onUploadProgress:(ev)=&gt;{<br> &nbsp; &nbsp; &nbsp; &nbsp;let {loaded,total} = ev;<br> &nbsp; &nbsp; &nbsp; &nbsp;progressBar.style.width = `${loaded\/total*100}%`<br> &nbsp; &nbsp;  }<br> &nbsp;  }).then((response)=&gt;{<br> &nbsp; &nbsp; &nbsp;console.log(response)<br> &nbsp;  })<br>  }<br>}<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-css-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u591a\u6587\u4ef6\u4e0a\u4f20\u53ca\u8fdb\u5ea6\u7ba1\u63a7\">\u591a\u6587\u4ef6\u4e0a\u4f20\u53ca\u8fdb\u5ea6\u7ba1\u63a7<\/h2>\n\n\n\n<p>\u540c\u5355\u6587\u4ef6\u5b9e\u73b0\u601d\u8def\u4e00\u6837\uff0c\u591a\u6587\u4ef6\u4e0a\u4f20\u9488\u5bf9\u6bcf\u4e2a\u6587\u4ef6\u8fdb\u884c\u8fdb\u5ea6\u7ba1\u63a7\u7684\u65b9\u6848\u5728\u4e8e\uff0c\u6bcf\u4e00\u4e2a\u6587\u4ef6\u90fd\u4f1a\u5355\u72ec\u8bf7\u6c42\u4e00\u6b21\u63a5\u53e3\u3002<\/p>\n\n\n\n<p>\u4f18\u70b9\uff1a\u53ef\u4ee5\u5bf9\u6bcf\u4e00\u4e2a\u6587\u4ef6\u8fdb\u884c\u7ba1\u63a7\uff0c\u5e76\u4e14\u4f1a\u964d\u4f4e\u6587\u4ef6\u4e0a\u4f20\u5230\u5bb9\u91cf<\/p>\n\n\n\n<p>\u7f3a\u70b9\uff1a\u4f1a\u91cd\u590d\u591a\u6b21\u7684\u8c03\u7528\u4e00\u4e2a\u63a5\u53e3\uff0c\u5bf9\u63a5\u53e3\u548c\u670d\u52a1\u5668\u9020\u6210\u7684\u538b\u529b\u8f83\u5927<\/p>\n\n\n\n<p>\u9488\u5bf9\u4e8e\u5408\u5e76\u591a\u6587\u4ef6\u8bf7\u6c42\u7684\u65b9\u5f0f\u4e4b\u524d\u5728 element \u6a21\u5757\u4e2d\u300a\u6587\u4ef6\u4e0a\u4f20\u300b\u4e2d\u603b\u7ed3\u8fc7 \u5b9e\u73b0\u7684\u65b9\u6cd5\uff0c \u611f\u5174\u8da3\u7684\u5c0f\u4f19\u4f34\u53ef\u4ee5\u79fb\u6b65\u53bb\u53e6\u4e00\u7bc7\u6587\u7ae0<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u7ed3\u679c\">\u5b9e\u73b0\u7ed3\u679c\uff1a<\/h3>\n\n\n\n<figure class=\"wp-block-image\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650959010(1).png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650959010(1).png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\"\/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u65b9\u5f0f\">\u5b9e\u73b0\u65b9\u5f0f<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"html\">html<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code> &nbsp;&lt;div class=\"container\"&gt;<br> &nbsp; &nbsp;&lt;div class=\"buttonContainer\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;input type=\"file\" id=\"inputInput\" multiple&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-select button\"&gt;\u9009\u62e9\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-submit button\"&gt;\u4e0a\u4f20\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div&gt;\u6587\u4ef6\u4ec5\u652f\u6301png\u683c\u5f0f\u7684\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;ul id=\"list\"&gt;<br> &nbsp; &nbsp; &nbsp; &nbsp;<br> &nbsp; &nbsp; &nbsp;&lt;\/ul&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp;&lt;\/div&gt;<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"javascript\">javascript<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code>let inputInput = document.querySelector(\"#inputInput\")<br>let select = document.querySelector(\".button-select\")<br>let submit = document.querySelector(\".button-submit\")<br>let list = document.querySelector(\"#list\")<br>let filesData;<br>\u200b<br>\/\/ \u83b7\u53d6\u672c\u5730\u6587\u4ef6<br>inputInput.onchange=()=&gt;{<br> &nbsp;filesData =Array.from(inputInput.files) <br> &nbsp;console.log(\"\u591a\u6587\u4ef6\u4e0a\u4f20\",filesData)<br> &nbsp;filesData.map((item)=&gt;{<br> &nbsp; &nbsp;list.innerHTML+= `<br> &nbsp; &nbsp; &nbsp;&lt;li&gt;<br> &nbsp; &nbsp; &nbsp; &nbsp;${item.name}<br> &nbsp; &nbsp; &nbsp; &nbsp;&lt;div class=\"progress\"&gt;<br> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&lt;div class=\"progressBar\" data-name=\"${item.name}\" style=\"width:10%\"&gt;&lt;\/div&gt;<br> &nbsp; &nbsp; &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;\/li&gt;<br> &nbsp; &nbsp;`<br>  })<br>}<br>\/\/ \u89e6\u53d1\u4e0a\u4f20\u7684click\u4e8b\u4ef6<br>select.onclick = ()=&gt;{<br> &nbsp;inputInput.click()<br>}<br>\/\/ \u63d0\u4ea4<br>submit.onclick = ()=&gt;{<br> &nbsp;console.log(filesData)<br> &nbsp;if(filesData.length){<br> &nbsp; &nbsp;filesData.map((item)=&gt;{<br> &nbsp; &nbsp; &nbsp;let formData = new FormData();<br> &nbsp; &nbsp; &nbsp;formData.append(\"files\",item)<br> &nbsp; &nbsp; &nbsp;axios({<br> &nbsp; &nbsp; &nbsp; &nbsp;method:\"POST\",<br> &nbsp; &nbsp; &nbsp; &nbsp;url:\"https:\/\/jsonplaceholder.typicode.com\/posts\/\",<br> &nbsp; &nbsp; &nbsp; &nbsp;data:formData,<br> &nbsp; &nbsp; &nbsp; &nbsp;onUploadProgress:(ev)=&gt;{<br> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;let el = document.querySelector(`div&#91;data-name=\"${item.name}\"]`)<br> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;let {loaded,total} = ev;<br> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;el.style.width = `${loaded\/total*100}%`<br> &nbsp; &nbsp; &nbsp;  }<br> &nbsp; &nbsp;  }).then((response)=&gt;{<br> &nbsp; &nbsp; &nbsp; &nbsp;console.log(response)<br> &nbsp; &nbsp;  })<br> &nbsp;  })<br>  }<br>}<\/code><\/pre>\n\n\n\n<p>\u4e0a\u9762 JS \u7684\u5b9e\u73b0\u903b\u8f91\u4e3a \u6bcf\u4e00\u4e2a li \u5143\u7d20\u7ed1\u5b9a\u552f\u4e00\u7684 \u81ea\u5b9a\u4e49\u5c5e\u6027\u76ee\u524d\u4ee5\u4e3a\u6587\u4ef6\u540d\u79f0\u4f5c\u4e3a\u552f\u4e00\u503c\uff0c\u5728\u8c03\u7528\u63a5\u53e3\u7684\u4e2d\u76d1\u542c onUploadProgress \u5229\u7528\u5f53\u524d\u7684 file \u5bf9\u8c61\u7684 name \u5c5e\u6027\uff0c\u627e\u5230\u76f8\u5bf9\u7684 DOM \u8282\u70b9\uff0c\u8ba1\u7b97\u8fdb\u5ea6\u5e76\u8d4b\u503c\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-css-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u62d6\u62fd\u4e0a\u4f20\">\u62d6\u62fd\u4e0a\u4f20<\/h2>\n\n\n\n<p>\u62d6\u62fd\u4e0a\u4f20\u7684\u5b9e\u73b0\u65b9\u5f0f \u4e3b\u8981\u4e8e\u501f\u52a9\u4e86 H5 \u7684API dragover \\ drop \u65b9\u6cd5\uff0c\u7528\u6765\u76d1\u542c\u5728\u6b64\u533a\u57df\u5185\u7684\u9f20\u6807\u79fb\u52a8\u548c\u653e\u4e0b\u4e8b\u4ef6\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u7ed3\u679c\">\u5b9e\u73b0\u7ed3\u679c<\/h3>\n\n\n\n<figure class=\"wp-block-image\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650962184(1).png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/1650962184(1).png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\"\/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u65b9\u5f0f\">\u5b9e\u73b0\u65b9\u5f0f<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"html\">html<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code> &nbsp;&lt;div class=\"container\" id=\"upWrapper\"&gt;<br> &nbsp; &nbsp;&lt;div class=\"content\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;img src=\".\/img\/\u4e0a\u4f20.png\" alt=\"\"&gt;\\<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp;&lt;\/div&gt;<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"javascript\">javascript<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code>let upWrapper = document.querySelector(\"#upWrapper\")<br> &nbsp;\/\/ \u8fdb\u5165\u4e8b\u4ef6<br> &nbsp;upWrapper.addEventListener(\"dragover\",(event)=&gt;{<br> &nbsp; &nbsp;event.preventDefault();<br>  })<br> &nbsp;\/\/ \u653e\u7f6e\u4e8b\u4ef6<br> &nbsp;upWrapper.addEventListener(\"drop\",(event)=&gt;{<br> &nbsp; &nbsp;event.preventDefault();<br> &nbsp; &nbsp;submit(event.dataTransfer.files)<br>  })<br> &nbsp;\/\/ \u63d0\u4ea4\u4e8b\u4ef6<br> &nbsp;const submit = (filesData)=&gt;{<br> &nbsp; &nbsp;let formData = new FormData();<br> &nbsp; &nbsp;formData.append(\"files\",filesData)<br> &nbsp; &nbsp;axios({<br> &nbsp; &nbsp; &nbsp;method:\"POST\",<br> &nbsp; &nbsp; &nbsp;url:\"https:\/\/jsonplaceholder.typicode.com\/posts\/\",<br> &nbsp; &nbsp; &nbsp;data:formData,<br> &nbsp;  }).then((response)=&gt;{<br> &nbsp; &nbsp; &nbsp;console.log(response)<br> &nbsp;  })<br>  }<\/code><\/pre>\n\n\n\n<p>\u4e0a\u9762 js \u7684\u4e3b\u8981\u903b\u8f91\u4e3a\uff0c \u5728 drop \u4e8b\u4ef6\u4e2d\u83b7\u53d6 \u6587\u4ef6\u7684\u5c5e\u6027 event.dataTransfer.files \uff0c\u7136\u540e\u5c06\u6587\u4ef6\u5c5e\u6027\u4f20\u7ed9\u670d\u52a1\u7aef\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-css-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u5927\u6587\u4ef6\u4e0a\u4f20\u548c\u65ad\u70b9\u7eed\u4f20\">\u5927\u6587\u4ef6\u4e0a\u4f20\u548c\u65ad\u70b9\u7eed\u4f20<\/h2>\n\n\n\n<p>\u5728\u4e00\u4e9b\u4e1a\u52a1\u9700\u6c42\u4e2d\uff0c\u9700\u8981\u7528\u6237\u4e0a\u4f20\u4e00\u4e9b\u5927\u5bb9\u91cf\u89c6\u9891\uff0c\u8fd9\u65f6\u7528\u4f20\u7edf\u7684\u6587\u4ef6\u4e0a\u4f20\u65b9\u5f0f\u4f1a\u9020\u6210\u4f20\u8f93\u6548\u7387\u53d8\u6162\u7684\u95ee\u9898\u3002\u5728\u4e0a\u4f20\u6587\u4ef6\u8fc7\u7a0b\u4e2d\u4e00\u65e6\u51fa\u73b0\u4e0a\u4f20\u5931\u8d25\uff0c\u5c31\u9700\u8981\u91cd\u65b0\u5c06\u6587\u4ef6\u6574\u4e2a\u91cd\u65b0\u4e0a\u4f20\u4e00\u904d\u3002\u8fd9\u6837\u5728\u65e0\u8bba\u662f\u7528\u6237\u63d0\u4f53\u9a8c\u8fd8\u662f\u670d\u52a1\u7aef\u90fd\u662f\u4e00\u79cd\u65f6\u95f4\u548c\u8d44\u6e90\u7684\u6d6a\u8d39\u3002<\/p>\n\n\n\n<p>\u5728\u89c2\u5bdf\u4e00\u4e9b\u5b58\u50a8\u5927\u5382\uff0c\u6bd4\u5982\u4e03\u725b\u4e91\u3001\u767e\u5ea6\u4e91\u76d8\u7b49\u670d\u52a1\u5546\uff0c\u4ed6\u4eec\u5728\u4e0a\u4f20\u548c\u4e0b\u8f7d\u7684\u65f6\u5019\u4f1a\u628a\u6587\u4ef6\u788e\u7247\u5316\uff0c\u8fd9\u6837\u4e0d\u4ec5\u53ef\u4ee5\u5927\u5927\u63d0\u9ad8\u4f20\u8f93\u901f\u5ea6\uff0c\u4e14\u4e5f\u517c\u5bb9\u7684\u65ad\u7535\u7eed\u4f20\u7684\u529f\u80fd\uff0c\u5373\u6587\u4ef6\u4e0a\u4f20\u5931\u8d25\uff0c\u7cfb\u7edf\u5bf9\u81ea\u52a8\u68c0\u7d22\u5931\u8d25\u7684\u6587\u4ef6\u788e\u7247\uff0c\u7b49\u5f85\u7528\u6237\u91cd\u65b0\u4e0a\u4f20\u8be5\u6587\u4ef6\u65f6\u4f1a\u81ea\u52a8\u771f\u7504\u522b\u5931\u8d25\u7684\u6587\u4ef6\u788e\u7247\u8fdb\u884c\u4e0a\u4f20\u3002<\/p>\n\n\n\n<p>\u4e0b\u9762\u5c31\u4ecb\u7ecd\u4e0b\u524d\u7aef\u662f\u5982\u4f55\u5b9e\u73b0\u5927\u6587\u4ef6\u4e0a\u4f20\u548c\u65ad\u70b9\u7eed\u4f20\u7684<\/p>\n\n\n\n<figure class=\"wp-block-image\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/%E6%97%A0%E6%A0%87%E9%A2%98-2022-04-27-1017.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  decoding=\"async\" data-original=\"https:\/\/raw.githubusercontent.com\/gongjianOnline\/ImgHosting\/main\/img\/%E6%97%A0%E6%A0%87%E9%A2%98-2022-04-27-1017.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\"\/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u5b9e\u73b0\u7684\u6280\u672f\u70b9\">\u5b9e\u73b0\u7684\u6280\u672f\u70b9<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u9700\u8981\u501f\u52a9 FileReader \u5b9e\u4f8b\u5bf9\u8c61\u8fdb\u884c Budder \u7684\u8f6c\u6362<\/li>\n\n\n\n<li>\u9700\u8981\u4f7f\u7528\u7b2c\u4e09\u653e Spark-md5 \u6765\u751f\u6210HASH<\/li>\n\n\n\n<li>\u9700\u8981\u4f7f\u7528\u6b63\u5219\u83b7\u53d6\u6587\u4ef6\u7684\u6269\u5c55\u540d\uff0c\u540e\u671f\u548c\u7ed3\u5408 HASH \u503c\u5408\u5e76\u6210\u4e00\u4e2a\u65b0\u7684\u6587\u4ef6\u540d\u79f0\uff08\u4e0a\u56fe\u6240\u793a\uff09<\/li>\n\n\n\n<li>\u9700\u8981\u501f\u52a9 file \u5bf9\u8c61\u4e2d\u7684 slice \u65b9\u6cd5\u5bf9\u6587\u4ef6\u5207\u5272\uff1b\u4f7f\u7528\u65b9\u6cd5\u548c\u6570\u7ec4\u7684 slice \u53c2\u6570\u4e00\u81f4<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"\u4ee3\u7801\u5b9e\u73b0\">\u4ee3\u7801\u5b9e\u73b0<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"html\">HTML<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code> &lt;div class=\"container\"&gt;<br> &nbsp; &nbsp;&lt;div class=\"buttonContainer\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;input type=\"file\" id=\"inputInput\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-select button\"&gt;\u9009\u62e9\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"button-submit button\"&gt;\u4e0a\u4f20\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div&gt;\u6587\u4ef6\u4ec5\u652f\u6301png\u683c\u5f0f\u7684\u6587\u4ef6&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;div class=\"progress\"&gt;<br> &nbsp; &nbsp; &nbsp;&lt;div class=\"progressBar\" style=\"width: 10%;\"&gt;&lt;\/div&gt;<br> &nbsp; &nbsp;&lt;\/div&gt;<br> &nbsp;&lt;\/div&gt;<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"javascript\">javascript<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code>let inputInput = document.querySelector(\"#inputInput\")<br>let select = document.querySelector(\".button-select\")<br>let submit = document.querySelector(\".button-submit\")<br>let progressBar = document.querySelector(\".progressBar\")<br>let chunks=&#91;]; \/\/ \u5207\u7247\u7684\u96c6\u5408<br>\u200b<br>\/\/ \u751f\u6210\u6587\u4ef6Buffer\u7684\u5c01\u88c5<br>const changeBuffer = (file)=&gt;{<br> &nbsp;return new Promise((resolve)=&gt;{<br> &nbsp; &nbsp;let fileReader = new FileReader();<br> &nbsp; &nbsp;fileReader.readAsArrayBuffer(file);<br> &nbsp; &nbsp;fileReader.onload = (event)=&gt;{<br> &nbsp; &nbsp; &nbsp;\/\/ \u6839\u636e\u6587\u4ef6\u5185\u5bb9\u751f\u6210HASH\u503c<br> &nbsp; &nbsp; &nbsp;let bufferData = event.target.result;<br> &nbsp; &nbsp; &nbsp;let spark = new SparkMD5.ArrayBuffer();<br> &nbsp; &nbsp; &nbsp;let HASH; \/\/ \u6587\u4ef6\u7684Hash\u540d<br> &nbsp; &nbsp; &nbsp;let suffix; \/\/\u83b7\u53d6\u6587\u4ef6\u540e\u7f00\u540d<br> &nbsp; &nbsp; &nbsp;spark.append(bufferData);<br> &nbsp; &nbsp; &nbsp;HASH = spark.end();<br> &nbsp; &nbsp; &nbsp;suffix = file.name.replace(\/.+\\.\/, \"\");<br> &nbsp; &nbsp; &nbsp;resolve({<br> &nbsp; &nbsp; &nbsp; &nbsp;bufferData,<br> &nbsp; &nbsp; &nbsp; &nbsp;HASH,<br> &nbsp; &nbsp; &nbsp; &nbsp;suffix,<br> &nbsp; &nbsp; &nbsp; &nbsp;fileName:`${HASH}.${suffix}`<br> &nbsp; &nbsp;  })<br> &nbsp;  }<br>  })<br>}<br>\u200b<br>\/\/ \u83b7\u53d6\u672c\u5730\u6587\u4ef6<br>inputInput.onchange= async ()=&gt;{<br> &nbsp;let files = inputInput.files&#91;0]<br> &nbsp;let {HASH,suffix,bufferData,fileName} = await changeBuffer(files);<br> &nbsp;let section = &#91;]; \/\/\u6587\u4ef6\u5207\u7247\u4e0a\u4f20\u7684\u8bb0\u5f55<br> &nbsp;\/*\u6587\u4ef6\u5207\u7247\u5904\u7406(\u4ee5\u56fa\u5b9a\u5927\u5c0f\u4e0a\u4f20\u4f18\u5148,\u5982\u679c\u5207\u7247\u6570\u91cf\u8fc7\u5927,\u5c31\u91c7\u7528\u56fa\u5b9a\u6570\u91cf)*\/<br> &nbsp;let max = 1024*100 \/\/ \u6bcf\u4e2a\u6587\u4ef6\u6700\u5927\u5728100KB<br> &nbsp;let count = Math.ceil(files.size \/ max); \/\/ \u4e00\u5171\u8981\u6709\u591a\u5c11\u5207\u7247<br> &nbsp;\/*\u8d85\u8fc7100\u4e2a\u5207\u7247,\u5c31\u91c7\u7528\u56fa\u5b9a\u6570\u91cf\u65b9\u5f0f\u4e0a\u4f20*\/<br> &nbsp;if(count&gt;100){<br> &nbsp; &nbsp;max = files.size \/ 100;<br> &nbsp; &nbsp;count = 100;<br>  }<br> &nbsp;for(let index=0;index&lt;count;index++){<br> &nbsp; &nbsp;chunks.push({<br> &nbsp; &nbsp; &nbsp; &nbsp;file:files.slice(index*max,max*(index+1)),<br> &nbsp; &nbsp; &nbsp; &nbsp;fileName:`${HASH}_${index+1}.${suffix}`<br> &nbsp;  })<br>  }<br>}<br>\u200b<br>\/\/ \u89e6\u53d1\u4e0a\u4f20\u7684click\u4e8b\u4ef6<br>select.onclick = ()=&gt;{<br> &nbsp;inputInput.click()<br>}<br>\u200b<br>\/\/ \u63d0\u4ea4<br>submit.onclick = ()=&gt;{<br> &nbsp;\/\/ \u4e0a\u4f20\u6210\u529f\u7684\u5904\u7406<br> &nbsp;let ChunkState = &#91;];<br> &nbsp;const upSuccess = (state)=&gt;{<br> &nbsp; &nbsp;ChunkState.push(state);<br> &nbsp; &nbsp;\/\/ \u5224\u65ad\u662f\u5426\u5168\u90e8\u4e3atrue<br> &nbsp; &nbsp;let ChunkStateEvery = ChunkState.every((item)=&gt;{return item==true})<br> &nbsp; &nbsp;if(chunks.length === ChunkState.length){<br> &nbsp; &nbsp; &nbsp;if(ChunkStateEvery){<br> &nbsp; &nbsp; &nbsp; &nbsp;\/\/ \u8c03\u7528\u540e\u53f0\u63a5\u53e3 \u901a\u77e5\u670d\u52a1\u5668\u53ef\u4ee5\u5bf9\u6587\u4ef6\u8fdb\u884c\u5408\u5e76<br> &nbsp; &nbsp; &nbsp; &nbsp;\/\/...<br> &nbsp; &nbsp; &nbsp; &nbsp;alter(\"\u6587\u4ef6\u4e0a\u4f20\u6210\u529f\")<br> &nbsp; &nbsp;  }else{<br> &nbsp; &nbsp; &nbsp; &nbsp;alter(\"\u6587\u4ef6\u4e0a\u4f20\u51fa\u9519\u6210\u91cd\u65b0\u4e0a\u4f20\")<br> &nbsp; &nbsp;  }<br> &nbsp;  }<br> &nbsp; &nbsp;\/\/ \u66f4\u65b0\u8fdb\u5ea6\u6761<br> &nbsp; &nbsp;progressBar.style.width = `${count(ChunkState,true)\/chunks.length*100}%`<br>  }<br> &nbsp;\/\/ \u5faa\u73af\u5207\u7247\u96c6\u5408\u9010\u4e2a\u8bf7\u6c42<br> &nbsp;chunks.map((item)=&gt;{<br> &nbsp; &nbsp;let formData = new FormData();<br> &nbsp; &nbsp;formData.append(\"files\",item.file)<br> &nbsp; &nbsp;formData.append(\"fileName\",item.fileName)<br> &nbsp; &nbsp;axios({<br> &nbsp; &nbsp; &nbsp;method:\"POST\",<br> &nbsp; &nbsp; &nbsp;url:\"https:\/\/jsonplaceholder.typicode.com\/posts\/\",<br> &nbsp; &nbsp; &nbsp;data:formData,<br> &nbsp;  }).then((response)=&gt;{<br> &nbsp; &nbsp; &nbsp;if(response.code == 200){<br> &nbsp; &nbsp; &nbsp; &nbsp;upSuccess(true);<br> &nbsp; &nbsp;  }<br> &nbsp;  }).catch(()=&gt;{<br> &nbsp; &nbsp; &nbsp;upSuccess(false);<br> &nbsp;  })<br>  })<br>}<br>\u200b<br>\/\/ \u7b97\u6cd5\u5c01\u88c5\u67e5\u627e\u6570\u7ec4\u4e2d\u67d0\u4e2a\u5143\u7d20\u51fa\u73b0\u7684\u6b21\u6570<br>const count = (arr, item)=&gt;{<br> &nbsp;var count = 0;<br> &nbsp;arr.forEach((e)=&gt; item === e ? count++:0);<br> &nbsp;return count;<br>}<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u5927\u6587\u4ef6\u5207\u7247\u4e0a\u4f20\u524d\u540e\u7aef\u6574\u4f53\u5b9e\u73b0\u903b\u8f91<\/h2>\n\n\n\n<p>\u6574\u4f53\u6d41\u7a0b\u53ef\u53c2\u8003\u4e0a\u65b9\u6d41\u7a0b\u56fe\uff0c\u6587\u4ef6\u91c7\u53d6 steam \u6d41\u65b9\u5f0f\u4f20\u9012\u7ed9\u540e\u7aef<\/p>\n\n\n\n<p>\u5b9e\u73b0\u6280\u672f\u6808 vue3 + KOA2 <a href=\"https:\/\/github.com\/gongjianOnline\/maxFileUPload\" data-type=\"link\" data-id=\"https:\/\/github.com\/gongjianOnline\/maxFileUPload\" target=\"_blank\" rel=\"noreferrer noopener\">demo\u5730\u5740<\/a><\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u6587\u4ef6\u5207\u7247\u4e0a\u4f20<\/h3>\n\n\n\n<p>\u5173\u952e\u5b57<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u6587\u4ef6\u5207\u7247<\/li>\n\n\n\n<li>\u5e76\u53d1\u4e0a\u4f20<\/li>\n\n\n\n<li>\u5408\u5e76\u6587\u4ef6<\/li>\n\n\n\n<li>\u6570\u636e\u6d41\u5f0f\u4f20\u8f93<\/li>\n\n\n\n<li>fs \u4f9d\u8d56\u589e\u5f3a<\/li>\n\n\n\n<li>\u8fdb\u5ea6\u7ba1\u63a7<\/li>\n\n\n\n<li>\u6682\u505c\u4e0a\u4f20<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\">\u524d\u7aef\u5b8c\u6574\u90e8\u5206<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;el-upload\n      ref=\"uploadRef\"\n      class=\"upload-demo\"\n      drag\n      action=\"https:\/\/run.mocky.io\/v3\/9d059bf9-4660-45f2-925d-ce80ad6c4d15\"\n      multiple\n      :on-change=\"handleUPload\"\n      :auto-upload=\"false\"\n    &gt;\n      &lt;el-icon class=\"el-icon--upload\"&gt;&lt;upload-filled \/&gt;&lt;\/el-icon&gt;\n      &lt;div class=\"el-upload__text\"&gt;\n        Drop file here or &lt;em&gt;click to upload&lt;\/em&gt;\n      &lt;\/div&gt;\n      &lt;template #tip&gt;\n        &lt;div class=\"el-upload__tip\"&gt;\n          jpg\/png files with a size less than 500kb\n        &lt;\/div&gt;\n      &lt;\/template&gt;\n    &lt;\/el-upload&gt;\n  &lt;\/div&gt;\n  &lt;img :src=\"imgUrl\" alt=\"\"&gt;\n  &lt;div&gt; \n    &lt;video :src=\"imgUrl\" controls&gt;&lt;\/video&gt;\n  &lt;\/div&gt;\n  &lt;!-- \u8fdb\u5ea6 --&gt;\n  &lt;div&gt;\u603b\u8fdb\u5ea6: {{progressAllNum}}&lt;\/div&gt;\n  &lt;div v-for=\"(value, key) in progressList\" :key=\"key\"&gt;\n    {{ key }}: {{ value }}\n  &lt;\/div&gt;\n\n  &lt;el-button class=\"ml-3\" type=\"success\" @click=\"handleSubmit\"&gt;\n    \u4e0a\u4f20\n  &lt;\/el-button&gt;\n  &lt;el-button class=\"ml-3\" type=\"success\" @click=\"handleClose\"&gt;\n    \u53d6\u6d88\u4e0a\u4f20\n  &lt;\/el-button&gt;\n&lt;\/template&gt;\n\n&lt;script lang=\"ts\" setup&gt;\nimport { UploadFilled } from '@element-plus\/icons-vue'\nimport {ref,reactive} from \"vue\"\nimport { ElMessage, type UploadInstance } from 'element-plus'\nimport axios from \"axios\"\n\n\/**\u4e0a\u4f20\u8868\u5355\u5b9e\u4f8b *\/\nconst uploadRef = ref&lt;UploadInstance&gt;();\n\n\/**\u4e0a\u4f20\u6587\u4ef6\u5b9e\u4f8b *\/\nconst fileInfo = ref&lt;any&gt;();\n\n\/**axios token *\/\nconst axiosTokenList = reactive&lt;any&#91;]&gt;(&#91;]);\n\n\/**\u8fdb\u5ea6\u6761 *\/\nconst progressList = reactive({})\nconst progressAllNum = ref(0)\n\n\/**\u9884\u89c8\u672c\u5730\u8def\u5f84 *\/\nconst imgUrl = ref(\"\")\n\/*\u6587\u4ef6 hash \u540d\u79f0 *\/\nlet fileHashName = \"\";\n\n\/*\u624b\u52a8\u63d0\u4ea4*\/\nconst handleSubmit = async ()=&gt;{\n   \/**\u751f\u6210hash *\/\n  fileHashName = await createHash(fileInfo.value.raw)\n   \/*\u6839\u636e\u6587\u4ef6\u7684 hash \u503c,\u8bf7\u6c42\u670d\u52a1\u7aef\u6587\u4ef6\u662f\u5426\u5b58\u5728\u5b9e\u73b0\u5927\u6587\u4ef6\u79d2\u4f20*\/\n  const result:any = await verifyFileUpload(fileHashName)\n  console.log(\"\u6d4b\u8bd5\u6587\u4ef6\u79d2\u4f20\",result)\n  if(result.data.code===101){\n    ElMessage({\n      message: '\u6587\u4ef6\u4f20\u8f93\u5b8c\u6210.',\n      type: 'success',\n    })\n    return\n  }\n  \/*\u6587\u4ef6\u5207\u7247*\/\n  const chunks = fileChunk(fileInfo.value.raw,fileHashName)\n  console.log(chunks)\n  \/*\u5e76\u884c\u4e0a\u4f20\u5207\u7247\u6587\u4ef6*\/  \n  const requestList = chunks.map((item)=&gt;{\n    \/*\u8bb0\u5f55\u6bcf\u4e00\u4e2a\u8bf7\u6c42\u7684 axios token \u7528\u4e8e\u53d6\u6d88\u8bf7\u6c42*\/  \n    const createToken = axios.CancelToken.source();\n    axiosTokenList.push(createToken)\n    return createFileUploadRequest(fileHashName,item.chunkFileName,item.chunk,createToken)\n  })\n  try {\n    await Promise.all(requestList);\n    \/**\u8bf7\u6c42\u6210\u529f\u540e\u901a\u77e5\u670d\u52a1\u7aef\u5408\u5e76\u6587\u4ef6*\/\n    await axios.get(`\/api\/marge\/${fileHashName}`)\n    console.log(\"\u4e0a\u4f20\u6210\u529f\")\n  } catch (error) {\n    console.log(\"\u4e0a\u4f20\u5931\u8d25\",error)\n  }\n}\n\n\nconst handleUPload = async (file)=&gt;{\n  console.log(file)\n  fileInfo.value = file;\n  \/**\u9884\u89c8 *\/\n  imgUrl.value = URL.createObjectURL(file.raw)\n}\n\n\n\/**\u83b7\u53d6 hash \u503c,\u8be5\u65b9\u6cd5\u4e3a\u624b\u52a8\u83b7\u53d6hash\u503c,\u53ef\u4ee5\u662f\u7528  Spark-md5 \u66ff\u4ee3*\/\nconst createHash = async (file)=&gt;{\n  const arrayBuffer = await file.arrayBuffer()\n  console.log(arrayBuffer)\n  \/**\n   * crypto.subtle\uff1a\u8fd9\u662f\u6d4f\u89c8\u5668\u63d0\u4f9b\u7684Web Cryptography API\u7684\u4e00\u4e2a\u5bf9\u8c61\uff0c\u7528\u4e8e\u8fdb\u884c\u5e95\u5c42\u5bc6\u7801\u5b66\u64cd\u4f5c\uff0c\u5982\u52a0\u5bc6\u3001\u89e3\u5bc6\u3001\u54c8\u5e0c\u7b49\u3002\n   * 'SHA-256' \u8868\u793a\u54c8\u5e0c\u7b97\u6cd5\u7684\u4e00\u79cd\u683c\u5f0f,\u53ef\u4ee5\u5c06\u4efb\u52a1\u957f\u5ea6\u7684\u6570\u636e\u6620\u5c04\u6210\u56fa\u5b9a\u957f\u5ea6(32\u5b57\u8282)\n   * *\/\n  const hashBuffer = await crypto.subtle.digest('SHA-256', arrayBuffer);\n  const hashResult = Array.from(new Uint8Array(hashBuffer)).map(b =&gt; b.toString(16).padStart(2, '0')).join(\"\")\n  return hashResult;\n}\n\n\n\/**\u6587\u4ef6\u5207\u7247 *\/\nconst fileChunk = (file,fileHashName)=&gt;{\n  let chunks:any&#91;] = &#91;];\n  let chunkSize = 1024 * 1024 * 100;\n  let count = Math.ceil(file.size \/ chunkSize);\n  for(let i=0;i&lt;count;i++){\n    let chunk = file.slice(i * chunkSize , (i + 1) * chunkSize)\n    chunks.push({\n      chunk,\n      chunkFileName:`${fileHashName}-${i}`\n    })\n  }\n  return chunks;\n}\n\n\/**\u521b\u5efa\u6587\u4ef6\u4e0a\u4f20\u8bf7\u6c42 *\/\nconst createFileUploadRequest = (fileName,chunkFileName,chunk,createToken)=&gt;{\n  return axios({\n    url:`\/api\/upload\/${fileName}`,\n    method:\"post\",\n    data:chunk,\n    headers:{\n      \"Content-Type\": \"application\/octet-stream\"\n    },\n    params:{\n      chunkFileName\n    },\n    \/*\u6839\u636e axios \u8ba1\u7b97\u4e0a\u4f20\u8fdb\u5165*\/\n    onUploadProgress:(progressEvent:any)=&gt;{\n      const percentCompleted = Math.round(progressEvent.loaded * 100 \/ progressEvent.total);\n      progressList&#91;chunkFileName] = percentCompleted;\n      var progressAll = calculateAverage();\n      progressAllNum.value = progressAll;\n    },\n    cancelToken:createToken.token\n  })\n}\n\n\/*\u8ba1\u7b97\u4e0a\u4f20\u603b\u8fdb\u5ea6*\/\nconst calculateAverage = ()=&gt;{\n  \/\/ \u83b7\u53d6\u5bf9\u8c61\u7684\u503c\u6570\u7ec4\n  const values = Object.values(progressList);\n  \/\/ \u5982\u679c\u5bf9\u8c61\u4e3a\u7a7a\uff0c\u5219\u8fd4\u56de 0\n  if (values.length === 0) {\n    return 0;\n  }\n  \/\/ \u4f7f\u7528reduce\u65b9\u6cd5\u8ba1\u7b97\u603b\u548c\n  const sum:any = values.reduce((acc:any, curr:any) =&gt; acc + curr, 0);\n  \/\/ \u8fd4\u56de\u5e73\u5747\u503c\n  return sum \/ values.length;\n}\n\n\n\/**\u6587\u4ef6\u79d2\u4f20\u9a8c\u8bc1 *\/\nconst verifyFileUpload = async (fileName)=&gt;{\n  return await axios.get(`\/api\/quickUpload\/${fileName}`);\n}\n\n\/**\u53d6\u6d88\u4e0a\u4f20 *\/\nconst handleClose = ()=&gt;{\n  axiosTokenList.forEach((item,index)=&gt;{\n    item.cancel('\u8bf7\u6c42\u88ab\u7528\u6237\u53d6\u6d88');\n  })\n}\n\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>\u4e0a\u8ff0\u4ee3\u7801\u4e2d\u5e76\u6ca1\u6709\u91c7\u7528\u4f20\u7edf\u7684 formData \u7684\u4e0a\u4f20\u65b9\u5f0f\uff0c\u800c\u662f <code>application\/octet-stream<\/code> ,\u56e0\u4e3a\u540e\u8005\u76f4\u63a5\u5c06\u6570\u636e\u8f6c\u6362\u6210\u4e8c\u8fdb\u5236\u6d41\u4f20\u7ed9\u540e\u53f0\uff0c\u8fd9\u79cd\u65b9\u5f0f\u9488\u5bf9\u4f20\u8f93\u7684\u6570\u636e\u66f4\u52a0\u7075\u6d3b\uff0c\u907f\u514d\u4e86\u88ab formData \u7c7b\u578b\u7684\u9650\u5236\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\">node\u7aef koa<\/h4>\n\n\n\n<p>\u907f\u514d\u4f7f\u7528 koa-body \u548c koa-bodyparser \u4e2d\u95f4\u4ef6\uff0c\u56e0\u4e3a\u8be5\u4e2d\u95f4\u4ef6\u5c4f\u853d\u4e86\u4e8c\u8fdb\u5236\u6d41\u6570\u636e\u4f20\u8f93\u683c\u5f0f<\/p>\n\n\n\n<p><strong>\u6e05\u9664\u6389 app.js \u4e2d\u7684<\/strong><\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const bodyparser = require('koa-bodyparser')\napp.use(bodyparser({\n  enableTypes:&#91;'json', 'form', 'text']\n}))<\/code><\/pre>\n\n\n\n<p>\u521b\u5efa\u8def\u7531,\u63a5\u53d7\u6587\u4ef6\u6d41<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const router = require('koa-router')()\r\nconst fs = require(\"fs-extra\");\r\nconst path = require('path');\r\n\r\n\/**\u4e0a\u4f20\u6587\u4ef6*\/\r\nrouter.post('\/upload\/:fileName', async (ctx, next) => {\r\n  const chunkFileName = ctx.params.fileName;\r\n  const fileName = ctx.request.query;\r\n  \/\/ \u786e\u4fdd\u5757\u6587\u4ef6\u5939\u5b58\u5728\r\n  await fs.ensureDir(`.\/uploads\/${chunkFileName}`);\r\n  \/*\u6587\u4ef6\u5199\u5165\u65b9\u6cd5\u5c01\u88c5*\/\r\n  const result = await fileInit(ctx,chunkFileName,fileName);\r\n  if(result.code === 101){\r\n    ctx.body = {\r\n      code:101,\r\n      data:{\r\n        chunkFileName,\r\n        fileName,\r\n        body:ctx.request.body\r\n      },\r\n      message:\"\u8bf7\u6c42\u6210\u529f\"\r\n    }\r\n  }else{\r\n    ctx.body = {\r\n      code:102,\r\n      data:{\r\n        chunkFileName,\r\n        fileName,\r\n        body:ctx.request.body\r\n      },\r\n      message:\"\u8bf7\u6c42\u5931\u8d25\"\r\n    }\r\n  }\r\n})\r\n\r\n\/**\u6587\u4ef6\u5904\u7406 *\/\r\nconst fileInit = (ctx,chunkFileName,fileName)=>{\r\n  return new Promise((resolve,reject)=>{\r\n    \/*\u521b\u5efa\u4e00\u4e2a buffer \u5bf9\u8c61*\/\r\n    let bufferData = Buffer.alloc(0);\r\n    ctx.req.on('data', async (chunk) => {\r\n      \/*\u5c06\u8bf7\u6c42\u7684 chunk \u5b57\u7b26\u4e32,\u8f6c\u6362\u6210 budder \u5bf9\u8c61*\/\r\n      const chunkData = Buffer.from(chunk);\r\n      \/*\u7531\u4e8e chunk \u4f1a\u88ab\u8bf7\u6c42\u5206\u6210\u4e0d\u540c\u7684\u6570\u636e\u5305,\u6240\u4ee5\u5728\u63a5\u53d7\u7684\u540c\u65f6\u5408\u5e76\u5230 bufferData \u53d8\u91cf\u4e2d\u5b58\u50a8*\/\r\n      bufferData = Buffer.concat(&#91;bufferData, chunkData]);\r\n    })\r\n    \/*\u5f53\u4f20\u8f93\u5b8c\u6210\u540e\u89e6\u53d1 end \u76d1\u542c*\/\r\n    ctx.req.on('end', async () => {\r\n      try {\r\n        \/*\u5c06\u4e34\u65f6\u5b58\u50a8\u7684 buffer \u5bf9\u8c61\u5230\u6587\u4ef6\u4e2d*\/\r\n        await fs.writeFileSync(`.\/uploads\/${chunkFileName}\/${fileName.chunkFileName}`,bufferData);\r\n        console.log(\"\u4f20\u8f93\u5b8c\u6210\")\r\n        resolve({code:101,message:\"\u6587\u4ef6\u4e0a\u4f20\u6210\u529f\"})\r\n      } catch (error) {\r\n        console.log(error)\r\n        resolve({code:102,message:\"\u6587\u4ef6\u4e0a\u4f20\u5931\u8d25\"})\r\n      }\r\n    })\r\n    \/*\u8bf7\u6c42\u4e2d\u65ad\u540e\u4f1a\u89e6\u53d1\u8be5\u76d1\u542c*\/\r\n    ctx.req.on(\"close\",async ()=>{\r\n      console.log(\"\u8bf7\u6c42\u88ab\u4e2d\u65ad\")\r\n      ctx.body = {\r\n        code:103,\r\n        message:\"\u8bf7\u6c42\u88ab\u4e2d\u65ad\"\r\n      }\r\n    })\r\n  })\r\n}\r\n\r\n\/**\u5408\u5e76\u6587\u4ef6\u63a5\u53e3 *\/\r\nrouter.get(\"\/marge\/:fileName\",async (ctx,next)=>{\r\n  const chunkFileName = ctx.params.fileName;\r\n  \/**\u4e0a\u4f20\u76ee\u5f55\u8def\u5f84*\/\r\n  const uploadsDirectory = `.\/uploads\/${chunkFileName}`;\r\n  \/**\u5408\u5e76\u540e\u7684\u6587\u4ef6\u8def\u5f84\u548c\u6587\u4ef6\u540d*\/\r\n  const mergedFilePath = `.\/uploads\/${chunkFileName}.mp4`;\r\n  \/**\u521b\u5efa\u4e00\u4e2a\u7a7a\u7684\u5408\u5e76\u6587\u4ef6*\/\r\n  fs.ensureFileSync(mergedFilePath);\r\n  \/**\u8bfb\u53d6\u4e0a\u4f20\u76ee\u5f55\u4e2d\u7684\u6240\u6709\u6587\u4ef6*\/\r\n  fs.readdir(uploadsDirectory,async (err, files) => {\r\n    const storedFiles = files.sort(compare)\r\n    \/**\u5bf9\u6bcf\u4e2a\u6587\u4ef6\u8fdb\u884c\u8fed\u4ee3*\/\r\n    storedFiles.forEach((file) => {\r\n        const filePath = path.join(uploadsDirectory, file);\r\n        \/**\u5c06\u5f53\u524d\u6587\u4ef6\u7684\u5185\u5bb9\u8ffd\u52a0\u5230\u5408\u5e76\u6587\u4ef6\u4e2d*\/\r\n        fs.appendFileSync(mergedFilePath, fs.readFileSync(filePath));\r\n        \/**\u5220\u9664\u539f\u59cb\u6587\u4ef6*\/\r\n        fs.unlinkSync(filePath);\r\n        console.log(`${file} \u5408\u5e76\u5b8c\u6210\uff0c\u5df2\u88ab\u5220\u9664`);\r\n    });\r\n    await fs.remove(uploadsDirectory)\r\n    console.log('\u6587\u4ef6\u5408\u5e76\u5b8c\u6210');\r\n  });\r\n\r\n\r\n\r\n  \/**\u6839\u636e\u6587\u4ef6\u540d\u6392\u5e8f *\/\r\n  function compare(a, b) {\r\n    const numA = parseInt(a.split('-')&#91;1]);\r\n    const numB = parseInt(b.split('-')&#91;1]);\r\n    return numA - numB;\r\n  }\r\n\r\n  ctx.body = {\r\n    code:101,\r\n    data:{},\r\n    message:\"\u8bf7\u6c42\u6210\u529f\"\r\n  }\r\n\r\n})\r\n\r\n\/*\u9a8c\u8bc1\u5f53\u524d\u6587\u4ef6\u662f\u5426\u5b58\u5728,\u5982\u679c\u5b58\u5728\u5219\u4e0d\u9700\u8981\u5ba2\u6237\u7aef\u91cd\u65b0\u4e0a\u4f20,\u76f4\u63a5\u8fd4\u56de\u76f8\u5bf9\u7684\u6210\u529f\u7ed3\u679c*\/\r\nrouter.get(\"\/quickUpload\/:fileName\",async (ctx,next)=>{\r\n  const fileName = ctx.params.fileName;\r\n  const result = await fs.pathExists(`.\/uploads\/${fileName}.mp4`);\r\n  if(result){\r\n    ctx.body = {\r\n      code:101,\r\n      message:\"\u8bf7\u6c42\u6210\u529f\"\r\n    }\r\n  }else{\r\n    ctx.body = {\r\n      code:102,\r\n      message:\"\u8bf7\u6c42\u6210\u529f\"\r\n    }\r\n  }\r\n  \r\n})\r\n\r\n\r\nmodule.exports = router<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u4f20\u7edf\u539f\u751f\u8868\u5355\u4e0a\u4f20\u6837\u5f0f\u5df2\u7ecf\u4e0d\u6ee1\u8db3\u73b0\u5728\u524d\u7aef\u53d1\u5c55\u7684\u9700\u6c42\uff0c\u73b0\u5728\u5e02\u573a\u901a\u5e38\u91c7\u7528\u5404\u79cd\u7b2c\u4e09\u65b9UI\u7ec4\u4ef6\u5e93\u6ee1\u8db3\u65e5\u5e38\u6240\u9700\u3002\u4f46\u5728\u5f00\u53d1\u4e2d [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[38],"tags":[],"class_list":["post-410","post","type-post","status-publish","format-standard","hentry","category-38"],"_links":{"self":[{"href":"https:\/\/gjweb.top\/index.php?rest_route=\/wp\/v2\/posts\/410","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/gjweb.top\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/gjweb.top\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/gjweb.top\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/gjweb.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=410"}],"version-history":[{"count":4,"href":"https:\/\/gjweb.top\/index.php?rest_route=\/wp\/v2\/posts\/410\/revisions"}],"predecessor-version":[{"id":918,"href":"https:\/\/gjweb.top\/index.php?rest_route=\/wp\/v2\/posts\/410\/revisions\/918"}],"wp:attachment":[{"href":"https:\/\/gjweb.top\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=410"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/gjweb.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=410"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/gjweb.top\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=410"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}