例如我们用某些 裁剪插件 得到的图片是
<img src="/UploadFiles/2021-04-02/ LCKuVgz5BDCSb13ZO99ZOdcZGvt4mJjzMVKqcha68iIePB86GAiOv8CDADlIUQBs7MD3wAAAABJRU5ErkJggg==">这样的,那这样的文件怎样在from 表单上传(当然我是举例,大部分的裁剪插件都是有内置的)
首先需要 吧 base64 流转换成 blob 对象,文件对象都继承它。
函数如下:
function getBlobBydataURI(dataURI,type) { var binary = atob(dataURI.split(',')[1]); var array = []; for(var i = 0; i < binary.length; i++) { array.push(binary.charCodeAt(i)); } return new Blob([new Uint8Array(array)], {type:type }); }那么剩下的就作为文件上传就ok
var $Blob= getBlobBydataURI(base64Data,'image/png'); var formData = new FormData(); formData.append("files", $Blob ,"file_"+Date.parse(new Date())+".png");全部代码是这样子的:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>上传用例</title> <meta content='width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no' name='viewport'> <script type="text/javascript"> /** * 根据base64 内容 取得 bolb * * @param dataURI * @returns Blob */ function getBlobBydataURI(dataURI,type) { var binary = atob(dataURI.split(',')[1]); var array = []; for(var i = 0; i < binary.length; i++) { array.push(binary.charCodeAt(i)); } return new Blob([new Uint8Array(array)], {type:type }); } /** * 上传 */ function upload(){ //base64 转 blob var $Blob= getBlobBydataURI(document.getElementsByTagName("img")[0].currentSrc,'image/jpeg'); var formData = new FormData(); formData.append("files", $Blob ,"file_"+Date.parse(new Date())+".jpeg"); //组建XMLHttpRequest 上传文件 var request = new XMLHttpRequest(); //上传连接地址 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> <button onclick="upload()">上传测试</button> <br /> 上传的图片: <img src="/UploadFiles/2021-04-02/9k=">以上所述是小编给大家介绍的JavaScript Base64 作为文件上传的实例代码解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!