클릭하면 브라우저에서 이미지 파일 다운로드
나는 엑셀 시트를 클릭하는 동안과 마찬가지로 이미지 파일을 다운로드할 수 있는 것이 필요합니다.
클라이언트 측 프로그래밍만 사용하여 이 작업을 수행할 수 있는 방법이 있습니까?
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript" src="Scripts/jquery-1.10.2.js">
$(document).ready(function () {
$("*").click(function () {
$("p").hide();
});
});
</script>
</head>
<script type="text/javascript">
document.onclick = function (e) {
e = e || window.event;
var element = e.target || e.srcElement;
if (element.innerHTML == "Image") {
//someFunction(element.href);
var name = element.nameProp;
var address = element.href;
saveImageAs1(element.nameProp, element.href);
return false; // Prevent default action and stop event propagation
}
else
return true;
};
function saveImageAs1(name, adress) {
if (confirm('you wanna save this image?')) {
window.win = open(adress);
//response.redirect("~/testpage.html");
setTimeout('win.document.execCommand("SaveAs")', 100);
setTimeout('win.close()', 500);
}
}
</script>
<body>
<form id="form1" runat="server">
<div>
<p>
<a href="http://localhost:55298/SaveImage/demo/Sample2.xlsx" target="_blank">Excel</a><br />
<a href="http://localhost:55298/SaveImage/demo/abc.jpg" id="abc">Image</a>
</p>
</div>
</form>
</body>
</html>
Excel 시트를 다운로드하는 경우 어떻게 작동해야 합니까(브라우저의 기능)?
HTML5를 사용하여 '다운로드' 속성을 링크에 추가할 수 있습니다.
<a href="/path/to/image.png" download>
그러면 호환되는 브라우저가 동일한 파일 이름(이 예제에서는 image.png)으로 이미지를 다운로드하라는 메시지를 표시합니다.
이 속성의 값을 지정하면 새 파일 이름이 됩니다.
<a href="/path/to/image.png" download="AwesomeImage.png">
업데이트: 2018년 봄부터 크로스 오리진에서는 더 이상 이 작업을 수행할 수 없습니다.그래서 당신이 만들고 싶다면,<a href="https://i.imgur.com/IskAzqA.jpg" download>
imgur.com 이외의 도메인에서는 의도한 대로 작동하지 않습니다.크롬 사용 중단 및 제거 안내
문서에 링크를 추가하여 크롬과 파이어폭스에서도 작동할 수 있었습니다.
var link = document.createElement('a');
link.href = 'images.jpg';
link.download = 'Download.jpg';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
리로이 & 리처드 파너비 킹:
업데이트: 2018년 봄부터 원산지가 다른 건초는 더 이상 이 작업을 수행할 수 없습니다.따라서 imgur.com 이외의 도메인에서 생성하려는 경우에는 의도한 대로 작동하지 않습니다.크롬 사용 중단 및 제거 안내
function forceDownload(url, fileName){
var xhr = new XMLHttpRequest();
xhr.open("GET", url, true);
xhr.responseType = "blob";
xhr.onload = function(){
var urlCreator = window.URL || window.webkitURL;
var imageUrl = urlCreator.createObjectURL(this.response);
var tag = document.createElement('a');
tag.href = imageUrl;
tag.download = fileName;
document.body.appendChild(tag);
tag.click();
document.body.removeChild(tag);
}
xhr.send();
}
Promise 및 async/wait를 사용하는 보다 현대적인 접근 방식:
async function toDataURL(url) {
const blob = await fetch(url).then(res => res.blob());
return URL.createObjectURL(blob);
}
그리고나서
async function download() {
const a = document.createElement("a");
a.href = await toDataURL("https://cdn1.iconfinder.com/data/icons/ninja-things-1/1772/ninja-simple-512.png");
a.download = "myImage.png";
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
}
여기에서 설명서 찾기: https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch
2018년 봄 업데이트
<a href="/path/to/image.jpg" download="FileName.jpg">
이 기능은 여전히 지원되지만 2018년 2월 현재 chrome은 교차 오리진 다운로드에 대해 이 기능을 비활성화했습니다. 즉, 파일이 동일한 도메인 이름에 위치한 경우에만 작동합니다.
크로스 도메인 다운로드를 비활성화한 크롬의 새로운 업데이트 이후 크로스 도메인 이미지를 다운로드하는 방법을 알아냈습니다.당신은 이것을 당신의 필요에 맞는 기능으로 수정할 수 있습니다.필요한 경우 추가 조사를 통해 이미지 마임 유형(jpeg, png, gif 등)을 얻을 수 있습니다.동영상으로도 이와 유사한 방법이 있을 수 있습니다.이것이 누군가에게 도움이 되기를 바랍니다!
리로이 & 리처드 파너비 킹:
업데이트: 2018년 봄부터 원산지가 다른 건초는 더 이상 이 작업을 수행할 수 없습니다.따라서 imgur.com 이외의 도메인에서 생성하려는 경우에는 의도한 대로 작동하지 않습니다.크롬 사용 중단 및 제거 안내
var image = new Image();
image.crossOrigin = "anonymous";
image.src = "https://is3-ssl.mzstatic.com/image/thumb/Music62/v4/4b/f6/a2/4bf6a267-5a59-be4f-6947-d803849c6a7d/source/200x200bb.jpg";
// get file name - you might need to modify this if your image url doesn't contain a file extension otherwise you can set the file name manually
var fileName = image.src.split(/(\\|\/)/g).pop();
image.onload = function () {
var canvas = document.createElement('canvas');
canvas.width = this.naturalWidth; // or 'width' if you want a special/scaled size
canvas.height = this.naturalHeight; // or 'height' if you want a special/scaled size
canvas.getContext('2d').drawImage(this, 0, 0);
var blob;
// ... get as Data URI
if (image.src.indexOf(".jpg") > -1) {
blob = canvas.toDataURL("image/jpeg");
} else if (image.src.indexOf(".png") > -1) {
blob = canvas.toDataURL("image/png");
} else if (image.src.indexOf(".gif") > -1) {
blob = canvas.toDataURL("image/gif");
} else {
blob = canvas.toDataURL("image/png");
}
$("body").html("<b>Click image to download.</b><br><a download='" + fileName + "' href='" + blob + "'><img src='" + blob + "'/></a>");
};
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
var pom = document.createElement('a');
pom.setAttribute('href', 'data:application/octet-stream,' + encodeURIComponent(text));
pom.setAttribute('download', filename);
pom.style.display = 'none';
document.body.appendChild(pom);
pom.click();
document.body.removeChild(pom);
이것은 당신의 문제에 대한 일반적인 해결책입니다.그러나 파일 확장자가 인코딩과 일치해야 하는 매우 중요한 부분이 있습니다.그리고 물론, downlowadImage 함수의 내용 매개변수는 당신의 이미지의 base64 인코딩 문자열이어야 합니다.
const clearUrl = url => url.replace(/^data:image\/\w+;base64,/, '');
const downloadImage = (name, content, type) => {
var link = document.createElement('a');
link.style = 'position: fixed; left -10000px;';
link.href = `data:application/octet-stream;base64,${encodeURIComponent(content)}`;
link.download = /\.\w+/.test(name) ? name : `${name}.${type}`;
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
}
['png', 'jpg', 'gif'].forEach(type => {
var download = document.querySelector(`#${type}`);
download.addEventListener('click', function() {
var img = document.querySelector('#img');
downloadImage('myImage', clearUrl(img.src), type);
});
});
a gif image: <image id="img" src="" />
<button id="png">Download PNG</button>
<button id="jpg">Download JPG</button>
<button id="gif">Download GIF</button>
이미지 URL 및 파일 이름을 수신하는 기능을 만들고 버튼을 사용하여 함수를 호출합니다.
function downloadImage(url, name){
fetch(url)
.then(resp => resp.blob())
.then(blob => {
const url = window.URL.createObjectURL(blob);
const a = document.createElement('a');
a.style.display = 'none';
a.href = url;
// the filename you want
a.download = name;
document.body.appendChild(a);
a.click();
window.URL.revokeObjectURL(url);
})
.catch(() => alert('An error sorry'));
}
<button onclick="downloadImage('https://upload.wikimedia.org/wikipedia/commons/thumb/0/02/Stack_Overflow_logo.svg/1280px-Stack_Overflow_logo.svg.png', 'LogoStackOverflow.png')" >DOWNLOAD</button>
Codepen.io JavaScript로 이미지 강제 다운로드
당신은 코드 없이 앵커 태그를 사용하여 이 파일을 직접 다운로드할 수 있습니다.
스니펫을 복사하여 텍스트 편집기에 붙여넣고 시도해 보십시오...!
<html>
<head>
</head>
<body>
<div>
<img src="https://upload.wikimedia.org/wikipedia/commons/1/1f/SMirC-thumbsup.svg" width="200" height="200">
<a href="#" download="https://upload.wikimedia.org/wikipedia/commons/1/1f/SMirC-thumbsup.svg"> Download Image </a>
</div>
</body>
</html>
2020년에 저는 Blob을 사용하여 이미지의 로컬 복사본을 만들고 브라우저는 파일로 다운로드합니다.이 사이트에서 테스트할 수 있습니다.
(function(global) {
const next = () => document.querySelector('.search-pagination__button-text').click();
const uuid = () => Math.random().toString(36).substring(7);
const toBlob = (src) => new Promise((res) => {
const img = document.createElement('img');
const c = document.createElement("canvas");
const ctx = c.getContext("2d");
img.onload = ({target}) => {
c.width = target.naturalWidth;
c.height = target.naturalHeight;
ctx.drawImage(target, 0, 0);
c.toBlob((b) => res(b), "image/jpeg", 0.75);
};
img.crossOrigin = "";
img.src = src;
});
const save = (blob, name = 'image.png') => {
const a = document.createElement("a");
a.href = URL.createObjectURL(blob);
a.target = '_blank';
a.download = name;
a.click();
};
global.download = () => document.querySelectorAll('.search-content__gallery-results figure > img[src]').forEach(async ({src}) => save(await toBlob(src), `${uuid()}.png`));
global.next = () => next();
})(window);
사용해 보십시오.
<a class="button" href="http://www.glamquotes.com/wp-content/uploads/2011/11/smile.jpg" download="smile.jpg">Download image</a>
할수있습니다
const urls = ['image.png', 'image1.png'];
urls.forEach((url) => {
window.open(url, "_blank");
});
// Pass desired URL as a param
function saveAs(uri) {
fetch(uri)
.then(res => res.blob()) // Gets the response and returns it as a blob
.then(blob => {
// Here, I use it to make an image appear on the page
let objectURL = URL.createObjectURL(blob);
let myImage = new Image();
myImage.href = blob;
myImage.download = generateFileName();
//Firefox requires the link to be in the body
document.body.appendChild(myImage);
//simulate click
myImage.click();
//remove the link when done
document.body.removeChild(myImage);
});
}
// Generate filenames for the image which is to be downloaded
function generateFileName() {
return `img${Math.floor(Math.random() * 90000) + 10000}`;
}
<html>
<head>
<script type="text/javascript">
function prepHref(linkElement) {
var myDiv = document.getElementById('Div_contain_image');
var myImage = myDiv.children[0];
linkElement.href = myImage.src;
}
</script>
</head>
<body>
<div id="Div_contain_image"><img src="YourImage.jpg" alt='MyImage'></div>
<a href="#" onclick="prepHref(this)" download>Click here to download image</a>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<button onclick="forceDownload('http://localhost:4000/1-2-free-png-image.png','test.png')">Download</button>
<script>
function forceDownload(url, fileName){
var xhr = new XMLHttpRequest();
xhr.open("GET", url, true);
xhr.responseType = "blob";
xhr.onload = function(){
var urlCreator = window.URL || window.webkitURL;
var imageUrl = urlCreator.createObjectURL(this.response);
var tag = document.createElement('a');
tag.href = imageUrl;
tag.download = fileName;
document.body.appendChild(tag);
tag.click();
document.body.removeChild(tag);
}
xhr.send();
}
</script>
</body>
</html>
나는 그것을 발견했습니다.
<a href="link/to/My_Image_File.jpeg" download>Download Image File</a>
저한테는 안 통했어요.왜 그런지 모르겠어요.
는 당신이 를수것을있는다포할함(음)를 할 수 했습니다.?download=true
링크 끝에 있는 매개 변수를 사용하여 강제로 다운로드합니다.Google Drive에서 이 기술을 사용하는 것을 본 것 같습니다.
링에다포다니합함을을 합니다.?download=true
당신의 href 끝에.
이 방법을 사용하여 파일 이름을 동시에 설정할 수도 있습니다.
링에다포다니합함을을 합니다.?download=true&filename=My_Image_File.jpeg
당신의 href 끝에.
.click() 기능과 태그를 사용하는 것은 어떻습니까?
(압축 버전)
<a id="downloadtag" href="examplefolder/testfile.txt" hidden download></a>
<button onclick="document.getElementById('downloadtag').click()">Download</button>
이제 js로 트리거할 수 있습니다.또한 다른 예와 같이 이미지 및 텍스트 파일이 열리지 않습니다.
(js-function 버전)
function download(){
document.getElementById('downloadtag').click();
}
<!-- HTML -->
<button onclick="download()">Download</button>
<a id="downloadtag" href="coolimages/awsome.png" hidden download></a>
이를 위해 js를 작성할 필요는 없으며, 다음을 사용하면 됩니다.
<a href="path_to/image.jpg" alt="something">Download image</a>
그리고 브라우저 자체가 자동으로 이미지를 다운로드합니다.
어떤 이유로 작동하지 않으면 다운로드 특성을 추가합니다.이 속성을 사용하여 다운로드 가능한 파일의 이름을 설정할 수 있습니다.
<a href="path_to/image.jpg" download="myImage">Download image</a>
언급URL : https://stackoverflow.com/questions/17527713/force-browser-to-download-image-files-on-click
'programing' 카테고리의 다른 글
IIS URL 다시 쓰기 vs URL 라우팅 (0) | 2023.09.01 |
---|---|
괄호 안의 숫자는 정말 무엇을 의미합니까? (0) | 2023.09.01 |
오라클 데이터베이스의 고유한 대/소문자 구분 안 함 제약 조건 (0) | 2023.08.27 |
ASP.NET MVC - 느린 초기 로드 (0) | 2023.08.27 |
루프에 대한 다중 처리? (0) | 2023.08.27 |