1. 程式人生 > >js 圖片base64轉file檔案的兩種方式

js 圖片base64轉file檔案的兩種方式

        最近專案中需要實現把圖片的base64編碼轉成file檔案的功能,然後再上傳至伺服器。起初是直接通過new File()的方式進行轉換,在各個主流的瀏覽器基本上都支援,Android也沒問題,但是在ios系統埋了個坑,ios11.4以下的系統上傳失敗。定位bug發現是new File()這個方法不相容ios系統,只能另闢蹊徑,最後找到一個方法就是:

                                        將base64轉成blob ——> blob轉成file

這種方式測試通過,解決了new File()不相容ios系統問題。下面將base64轉file檔案兩種方式的程式碼貼出來:

1.通過new File()將base64轉換成file檔案,此方式需考慮瀏覽器相容問題。

    //將base64轉換為檔案
    dataURLtoFile: function(dataurl, filename) { 
	    var arr = dataurl.split(','),
	        mime = arr[0].match(/:(.*?);/)[1],
	        bstr = atob(arr[1]),
	        n = bstr.length,
	        u8arr = new Uint8Array(n);
	    while (n--) {
	        u8arr[n] = bstr.charCodeAt(n);
	    }
	    return new File([u8arr], filename, { type: mime });
	},


    //呼叫
    var file = dataURLtoFile(base64Data, imgName);

2.先將base64轉換成blob,再將blob轉換成file檔案,此方法不存在瀏覽器不相容問題。

    //將base64轉換為blob
    dataURLtoBlob: function(dataurl) { 
        var arr = dataurl.split(','),
            mime = arr[0].match(/:(.*?);/)[1],
            bstr = atob(arr[1]),
            n = bstr.length,
            u8arr = new Uint8Array(n);
        while (n--) {
            u8arr[n] = bstr.charCodeAt(n);
        }
        return new Blob([u8arr], { type: mime });
    },
    //將blob轉換為file
    blobToFile: function(theBlob, fileName){
       theBlob.lastModifiedDate = new Date();
       theBlob.name = fileName;
       return theBlob;
    },
    //呼叫
    var blob = dataURLtoBlob(base64Data);
    var file = blobToFile(blob, imgName);

        目前方法二在專案中已經可以正常使用。

        本人前端小新,如有不正確的地方,歡迎各位大牛指正。