JavaScript Base64 作为文件上传的实例代码解析
例如我们用某些裁剪插件得到的图片是
<imgsrc="">
这样的,那这样的文件怎样在from表单上传(当然我是举例,大部分的裁剪插件都是有内置的)
首先需要吧base64流转换成blob对象,文件对象都继承它。
函数如下:
functiongetBlobBydataURI(dataURI,type){ varbinary=atob(dataURI.split(',')[1]); vararray=[]; for(vari=0;i<binary.length;i++){ array.push(binary.charCodeAt(i)); } returnnewBlob([newUint8Array(array)],{type:type}); }
那么剩下的就作为文件上传就ok
var$Blob=getBlobBydataURI(base64Data,'image/png'); varformData=newFormData(); formData.append("files",$Blob,"file_"+Date.parse(newDate())+".png");
全部代码是这样子的:
<!DOCTYPEhtml> <html> <head> <metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/> <title>上传用例</title> <metacontent='width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no'name='viewport'> <scripttype="text/javascript"> /** *根据base64内容取得bolb * *@paramdataURI *@returnsBlob */ functiongetBlobBydataURI(dataURI,type){ varbinary=atob(dataURI.split(',')[1]); vararray=[]; for(vari=0;i<binary.length;i++){ array.push(binary.charCodeAt(i)); } returnnewBlob([newUint8Array(array)],{type:type}); } /** *上传 */ functionupload(){ //base64转blob var$Blob=getBlobBydataURI(document.getElementsByTagName("img")[0].currentSrc,'image/jpeg'); varformData=newFormData(); formData.append("files",$Blob,"file_"+Date.parse(newDate())+".jpeg"); //组建XMLHttpRequest上传文件 varrequest=newXMLHttpRequest(); //上传连接地址 request.open("POST","www.xxx.com"); request.onreadystatechange=function() { if(request.readyState==4) { if(request.status==200){ console.log("上传成功"); }else{ console.log("上传失败,检查上传地址是否正确"); } } } request.send(formData); } </script> </head> <body> <buttononclick="upload()">上传测试</button> <br/> 上传的图片: <imgsrc=""/> </body> </html>
以上所述是小编给大家介绍的JavaScriptBase64作为文件上传的实例代码解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!