ファイルから抽出された Base64String (例: "AAAA....~") を JavaScript ファイル オブジェクトに変換します。
私が言っている JavaScript ファイル オブジェクトは次のコードのようなものです:
HTML:
<input type="file" id="selectFile" >
JS:
$('#selectFile').on('change', function(e) {
var file = e.target.files[0];
console.log(file)
}
'file' 変数は JavaScript ファイル オブジェクトです。したがって、base64 文字列を JavaScript ファイル オブジェクトに変換したいと思います。
HTML ファイル入力フォームを使用せずに、base64 文字列 (ファイルから他のアプリによってエンコードされたもの) をデコードしてファイル オブジェクトを取得したいだけです。
ありがとう。
ベストアンサー1
方法1:dataURL に対してのみ機能し、他のタイプの URL に対しては機能しません。
function dataURLtoFile(dataurl, filename) {
var arr = dataurl.split(','),
mime = arr[0].match(/:(.*?);/)[1],
bstr = atob(arr[arr.length - 1]),
n = bstr.length,
u8arr = new Uint8Array(n);
while(n--){
u8arr[n] = bstr.charCodeAt(n);
}
return new File([u8arr], filename, {type:mime});
}
//Usage example:
var file = dataURLtoFile('data:text/plain;base64,aGVsbG8=','hello.txt');
console.log(file);
方法2:あらゆるタイプの URL (http URL、dataURL、blobURL など) で機能します。
// return a promise that resolves with a File instance
function urltoFile(url, filename, mimeType){
if (url.startsWith('data:')) {
var arr = url.split(','),
mime = arr[0].match(/:(.*?);/)[1],
bstr = atob(arr[arr.length - 1]),
n = bstr.length,
u8arr = new Uint8Array(n);
while(n--){
u8arr[n] = bstr.charCodeAt(n);
}
var file = new File([u8arr], filename, {type:mime || mimeType});
return Promise.resolve(file);
}
return fetch(url)
.then(res => res.arrayBuffer())
.then(buf => new File([buf], filename,{type:mimeType}));
}
//Usage example:
urltoFile('data:text/plain;base64,aGVsbG8=', 'hello.txt','text/plain')
.then(function(file){ console.log(file);});