이미지를 URL에서 Base64로 변환
이미지 파일을 사용하여 웹 서비스로 전송해야 하는 이미지의 URL을 얻습니다.여기서 이미지를 로컬로 시스템에 저장해야 합니다.
사용 중인 코드:
var imagepath = $("#imageid").val();// from this getting the path of the selected image
that var st = imagepath.replace(data:image/png or jpg; base64"/"");
이미지 URL을 BASE64로 변환하는 방법은 무엇입니까?
HTML
<img id="imageid" src="https://www.google.de/images/srpr/logo11w.png">
자바스크립트
function getBase64Image(img) {
var canvas = document.createElement("canvas");
canvas.width = img.width;
canvas.height = img.height;
var ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0);
var dataURL = canvas.toDataURL("image/png");
return dataURL.replace(/^data:image\/?[A-z]*;base64,/);
}
var base64 = getBase64Image(document.getElementById("imageid"));
@Md. 하산 마흐무드에게 특별히 감사드립니다. 제 의견에 어떤 이미지 마임 유형과도 작동하는 개선된 정규식을 제공해 주셔서 감사합니다!
이 방법은 완벽하게 지원되는 캔버스 요소가 필요합니다.
다음 답변 보기: https://stackoverflow.com/a/20285053/5065874 by @HaNdTriX
기본적으로 그는 이 기능을 구현했습니다.
function toDataUrl(url, callback) {
var xhr = new XMLHttpRequest();
xhr.onload = function() {
var reader = new FileReader();
reader.onloadend = function() {
callback(reader.result);
}
reader.readAsDataURL(xhr.response);
};
xhr.open('GET', url);
xhr.responseType = 'blob';
xhr.send();
}
이 경우 다음과 같이 사용할 수 있습니다.
toDataUrl(imagepath, function(myBase64) {
console.log(myBase64); // myBase64 is the base64 string
});
오늘날 자바스크립트에서는 이것도 작동할 것입니다.
const getBase64FromUrl = async (url) => {
const data = await fetch(url);
const blob = await data.blob();
return new Promise((resolve) => {
const reader = new FileReader();
reader.readAsDataURL(blob);
reader.onloadend = () => {
const base64data = reader.result;
resolve(base64data);
}
});
}
getBase64FromUrl('https://lh3.googleusercontent.com/i7cTyGnCwLIJhT1t2YpLW-zHt8ZKalgQiqfrYnZQl975-ygD_0mOXaYZMzekfKW_ydHRutDbNzeqpWoLkFR4Yx2Z2bgNj2XskKJrfw8').then(console.log)
이것은 당신의 html입니다.
<img id="imageid" src="">
<canvas id="imgCanvas" />
Javascript는 다음과 같아야 합니다.
var can = document.getElementById("imgCanvas");
var img = document.getElementById("imageid");
var ctx = can.getContext("2d");
ctx.drawImage(img, 10, 10);
var encodedBase = can.toDataURL();
'encodedBase'에는 이미지의 Base64 인코딩이 포함되어 있습니다.
맨 위의 답을 사용하려고 시도하지만 발생합니다.Uncaught DOMException: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported
.
나는 이것이 교차 도메인 문제 때문이라는 것을 발견했다, 해결책은
function convert(oldImag, callback) {
var img = new Image();
img.onload = function(){
callback(img)
}
img.setAttribute('crossorigin', 'anonymous');
img.src = oldImag.src;
}
function getBase64Image(img,callback) {
convert(img, function(newImg){
var canvas = document.createElement("canvas");
canvas.width = newImg.width;
canvas.height = newImg.height;
var ctx = canvas.getContext("2d");
ctx.drawImage(newImg, 0, 0);
var base64=canvas.toDataURL("image/png");
callback(base64)
})
}
getBase64Image(document.getElementById("imageid"),function(base64){
// base64 in here.
console.log(base64)
});
사용할 수 있는 항목:
function ViewImage(){
function getBase64(file) {
return new Promise((resolve, reject) => {
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = () => resolve(reader.result);
reader.onerror = error => reject(error);
});
}
var file = document.querySelector('input[type="file"]').files[0];
getBase64(file).then(data =>$("#ImageBase46").val(data));
}
변경 시 입력에 추가=이미지 보기();
<input id="inputFileToLoad" type="file" onchange="encodeImageFileAsURL();" />
<div id="imgTest"></div>
<script type='text/javascript'>
function encodeImageFileAsURL() {
var filesSelected = document.getElementById("inputFileToLoad").files;
if (filesSelected.length > 0) {
var fileToLoad = filesSelected[0];
var fileReader = new FileReader();
fileReader.onload = function(fileLoadedEvent) {
var srcData = fileLoadedEvent.target.result; // <--- data: base64
var newImage = document.createElement('img');
newImage.src = srcData;
document.getElementById("imgTest").innerHTML = newImage.outerHTML;
alert("Converted Base64 version is " + document.getElementById("imgTest").innerHTML);
console.log("Converted Base64 version is " + document.getElementById("imgTest").innerHTML);
}
fileReader.readAsDataURL(fileToLoad);
}
}
</script>
let baseImage = new Image;
baseImage.setAttribute('crossOrigin', 'anonymous');
baseImage.src = your image url
var canvas = document.createElement("canvas");
canvas.width = baseImage.width;
canvas.height = baseImage.height;
var ctx = canvas.getContext("2d");
ctx.drawImage(baseImage, 0, 0);
var dataURL = canvas.toDataURL("image/png");
"CORS 지원 이미지"에 대한 추가 정보: MDN 설명서
imageToBase64 = (URL) => {
let image;
image = new Image();
image.crossOrigin = 'Anonymous';
image.addEventListener('load', function() {
let canvas = document.createElement('canvas');
let context = canvas.getContext('2d');
canvas.width = image.width;
canvas.height = image.height;
context.drawImage(image, 0, 0);
try {
localStorage.setItem('saved-image-example', canvas.toDataURL('image/png'));
} catch (err) {
console.error(err)
}
});
image.src = URL;
};
imageToBase64('image URL')
저는 그냥 제가 어떻게 했는지를 게시하고 싶었어요.이것은 기본적으로 @Haialaluf의 접근 방식이지만 조금 더 짧습니다.
const imageUrlToBase64 = async (url) => {
const data = await fetch(url)
const blob = await data.blob();
const reader = new FileReader();
reader.readAsDataURL(blob);
reader.onload = () => {
const base64data = reader.result;
return base64data
}
}
이것은 사용합니다.canvas.ToDataURL(...)
function getBase64Image(img) {
const canvas = document.createElement("canvas");
const ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0);
const dataURL = canvas.toDataURL("image/png");
return dataURL;
}
이것은 더 많은 경우에 효과가 있습니다. 왜냐하면 그것은 다시 가져와 캔버스를 피하기 때문입니다.img.src
const getBase64FromUrl = async (url) => {
const data = await fetch(url);
const blob = await data.blob();
return new Promise((resolve) => {
const reader = new FileReader();
reader.readAsDataURL(blob);
reader.onloadend = () => {
const base64data = reader.result;
resolve(base64data);
}
});
}
추가적으로, 이 기능은 페이지의 모든 이미지를 읽기 전에 두 기능을 모두 사용하고 작동하면 첫 번째 기능을 사용하며, 그렇지 않으면 두 번째 기능을 사용하며, alt 텍스트를 제목으로 하고 base64를 원본으로 하는 이미지의 마크다운 이미지 임베딩을 반환합니다.
const images = document.getElementsByTagName('img');
[...images].forEach(async img => {
let base64;
try {
base64 = getBase64Image(img);
} catch (error) {
base64 = await getBase64FromUrl(img.src);
};
const markdown = `![${img.alt}](${base64})`;
console.log(markdown, img);
})
아부바카르 아흐마드의 대답의 타이프스크립트 버전입니다.
function imageTo64(
url: string,
callback: (path64: string | ArrayBuffer) => void
): void {
const xhr = new XMLHttpRequest();
xhr.open('GET', url);
xhr.responseType = 'blob';
xhr.send();
xhr.onload = (): void => {
const reader = new FileReader();
reader.readAsDataURL(xhr.response);
reader.onloadend = (): void => callback(reader.result);
}
}
언급URL : https://stackoverflow.com/questions/22172604/convert-image-from-url-to-base64
'programing' 카테고리의 다른 글
Spring Data JPA - 여러 EnableJpa 저장소 (0) | 2023.08.16 |
---|---|
파일 저장소로서의 MongoDB (0) | 2023.08.16 |
오류: \node_modules\@angular-devkit\build-angular\src\angular-cli-files\models의 'core-js/es7/reflect'를 확인할 수 없습니다. (0) | 2023.08.16 |
Excel은 다시 입력하지 않는 한 VBA 함수가 있는 공식을 오차로 계산하고 있습니다. (0) | 2023.08.16 |
MySQL이 밀리초/마이크로초 정밀도를 지원하지 않는 이유는 무엇입니까? (0) | 2023.08.11 |