您好,登錄后才能下訂單哦!
例如我們用某些 裁剪插件 得到的圖片是
<img src=" KEAUFFR0Cbng3nQPw68ArZdAlOZppPFIBhH5EAB8b+Tlt9MYQ6i1BuqFaq1CKSVcxZ2Acs6406KUgpt5/ 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="" /> </body> </html>
以上所述是小編給大家介紹的JavaScript Base64 作為文件上傳的實例代碼解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。