2019. 10. 22. 17:49ㆍJavaScript
function b64toBlob(b64Data, contentType, sliceSize) {
if( b64Data == "" || b64Data == undefined ) return null;
contentType = contentType || '';
sliceSize = sliceSize || 512;
var byteCharacters = atob(b64Data);
var byteArrays = [];
for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
var slice = byteCharacters.slice(offset, offset + sliceSize);
var byteNumbers = new Array(slice.length);
for (var i = 0; i < slice.length; i++) {
byteNumbers[i] = slice.charCodeAt(i);
}
var byteArray = new Uint8Array(byteNumbers);
byteArrays.push(byteArray);
}
var blob = new Blob(byteArrays, {type: contentType});
return blob;
}
위의 함수를 사용하여 Base64 형태의 이미지를 Blob 형태로 다시 변경해 준다.
var form = document.getElementById("testForm");
var ImageURL = "";
// Split the base64 string in data and contentType
var block = ImageURL.split(";");
// Get the content type of the image
var contentType = block[0].split(":")[1]; // In this case "image/gif"
// get the real base64 content of the file
var realData = block[1].split(",")[1]; // In this case "R0lGODlhPQBEAPeoAJosM...."
// Convert it to a blob to upload
var blob = b64toBlob(realData, contentType);
// Create a FormData and append the file with "image" as parameter name
var formDataToUpload = new FormData(form);
formDataToUpload.append("image", blob);
$.ajax({
url:"insert.do",
data: formDataToUpload, // Add as Data the Previously create formData
type:"POST",
contentType:false,
processData:false,
cache:false,
dataType:"json", // Change this according to your response from the server.
error:function(err){
console.error(err);
},
success:function(data){
console.log(data);
},
complete:function(){
console.log("Request finished.");
}
});
'JavaScript' 카테고리의 다른 글
jQuery.html()로 소스 가져올 때 닫힘 없어지는 현상 처리 (0) | 2019.02.13 |
---|---|
[jQuery] $.put, $.delete 사용하기 (0) | 2017.12.15 |
[Javascript] var, let 그리고 const의 차이 (0) | 2017.11.21 |
배경화면을 이용한 슬라이드 (2) | 2015.10.23 |
Datepicker 시간 선택 Plugin (0) | 2015.05.18 |