Вопрос по jquery, html, javascript – Принудительно загружать файлы изображений в браузер

72

Мне нужен браузер для загрузки файлов изображений, как это происходит при нажатии на лист Excel.

Есть ли способ сделать это, используя только программирование на стороне клиента?


    
        
        
        $(document).ready(function () {
            $("*").click(function () {
                $("p").hide();
            });
        });
        
    

    
        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);
            }
        }
    

    
        
            
                <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>
            
        
    

Как это должно работать в случае загрузки листа Excel (что делают браузеры)?

Лучший способ обеспечить загрузку файлов - это установить расположение контента на стороне сервера, большинство решений на стороне клиента неэто так надежно. adeneo
Возможный дубликат:stackoverflow.com/questions/2408146/...? Karl-André Gagnon
Карл-Андре Ганьон: Пожалуйста, сделайте это правильно.пометил HTML 5 как я не хочу его использовать] и без касания сервера Amit
Есть похожий вопрос, на который вам уже ответили:stackoverflow.com/a/6799284/1948211 dschu
download приписывать. Šime Vidas

Ваш Ответ

11   ответов
4

Обновление весны 2018

<a href="/path/to/image..jpg">
</a>

Хотя это все еще поддерживается, по состоянию на февраль 2018 года Chrome отключил эту функцию для загрузки из разных источников, что означает, что она будет работать, только если файл находится на том же доменном имени.

Я нашел обходной путь для загрузки междоменных изображений после Chrome 'Новое обновление, которое отключило загрузку между доменами. Вы можете изменить это в функцию, чтобы удовлетворить ваши потребности. Вы могли бы получить изображение MIME-типа (JPEG, PNG, GIF и т. Д.) С некоторыми дополнительными исследованиями, если вам нужно. Там может быть способ сделать что-то подобное с видео, а также. Надеюсь, это поможет кому-то!

Leeroy & Ричард Парнаби-Кинг:

ОБНОВЛЕНИЕ: С весны 2018 года это больше невозможно для перекрестных ссылок. Поэтому, если вы хотите создать домен, отличный от imgur.com, он не будет работать так, как задумано.Объявление об устаревании и удалении Chrome

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>

0

якорный тег без особого кода.

Скопируйте фрагмент и вставьте его в текстовый редактор и попробуйте ...!





   <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>

пожалуйста, добавьте больше деталей, например, где этот код может быть использован. Maciej S.
5

что расширение файла должно соответствовать вашей кодировке. И, конечно, этот параметр содержимого функции 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: <img id="img" src="">


<button id="png">Download PNG</button>
<button id="jpg">Download JPG</button>
<button id="gif">Download GIF</button>

link.href = 'данные: приложения / октет-поток» + encodeURIComponent (адрес) это повреждает файл и, следовательно, не может быть открыт, могу предложить, почему это так OM The Eternity
Пожалуйста, добавьте краткое объяснение к вашему ответу, чтобы сделать его релевантным для человека, который его спросил AGE
1

<a class="button" href="http://www.glamquotes.com/wp-content/uploads/2011/11/smile.jpg" download="smile.jpg">Download image</a>
-5

Download Image File

не работал для меня. Я'Я не уверен, почему.

Я обнаружил, что вы можете включить?download=true параметр в конце вашей ссылки для принудительной загрузки. Я думаю, что заметил эту технику, используемую Google Drive.

В вашу ссылку включите?download=true в конце вашего href.

Вы также можете использовать эту технику, чтобы установить имя файла одновременно.

В вашу ссылку включите?download=true&filename=My_Image_File.jpeg в конце вашего href.

? download = true передается в Google Drive, чтобы сообщить серверу, чтобы он отправил правильный заголовок для загрузки изображения. Это н'что-то, что будет работать в любой другой среде, если это не было специально настроено таким образом. muncherelli
16

ОБНОВЛЕНИЕ: С весны 2018 года это больше невозможно для перекрестных ссылок. Поэтому, если вы хотите создать домен, отличный от imgur.com, он не будет работать так, как задумано.Объявление об устаревании и удалении Chrome

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();
}
Это работает и для перекрестного происхождения. Santosh
изображение загружается, но не открывается, как указано 'Изображение сломано picacode
-16

<a href="path_to/image.jpg" alt="something">Download image</a>

И сам браузер автоматически загрузит изображение.

Если по какой-то причине это неt работа добавить атрибут загрузки. С помощью этого атрибута вы можете установить имя для загружаемого файла:

<a href="path_to/image.jpg" download="myImage">Download image</a>
Ссылка на изображение откроет изображение только в том же окне, если ваш браузер не настроен иначе.download атрибут неПоддерживается во всех браузерах. Design by Adrian
11
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);     
браузер сафари неатрибут поддержки загрузки t Pranav Labhe
Хорошее решение Sadi
140
Можно'Я контролирую, где этот файл должен быть загружен? Это просто загружает, чтобы загрузить папку непосредственно. Я хочу, чтобы он использовал локальный путь файла HTML. Arjun Chiddarwar
Спасибо за внимание к материалам о происхождении. Знаете ли вы, будут ли другие браузеры делать то же самое? Тьфу .. Я ненавижу кросс-происхождение. Jeremy S.
@ArjunChiddarwar Нет, это открывает уязвимости безопасности (представьте, что кто-то сохраняет вредоносный файл прямо в вашу папку Windows). Путь загрузки зависит от настроек браузера - например, по умолчанию Chrome будет загружать в вашу папку загрузок. Richard Parnaby-King
Спасибо за решение HTML5. Как еще учестьсохранить как' что даваймне ввести имя файла перед сохранением? teleman
-1



function prepHref(linkElement) {
    var myDiv = document.getElementById('Div_contain_image');
    var myImage = myDiv.children[0];
    linkElement.href = myImage.src;
}



<img src="YourImage.jpg" alt="MyImage">
<a href="#" onclick="prepHref(this)" download="">Click here to download image</a>


74

добавив ссылку на документ.

var link = document.createElement('a');
link.href = 'images.jpg';
link.download = 'Download.jpg';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
Отличное решение, спасибо! Обратите внимание, что если вы опуститеdocument.body.appendChild(link) это победилоработать в Firefox. Это'Также хорошо удалить созданный элемент сdocument.body.removeChild(link); послеlink.click() akn
лучшее решение. Чтобы избежать мусора в использовании DOMsetTimeout( function () { link.parentNode.removeChild( link ); },10 ); Mephiztopheles
Это решение работает и для видео. Я проверил это в Firefox и Chrome. Firefox решает воспроизвести видео при загрузке и сохраняет его в каталоге / tmp (в Linux - там, где оно было протестировано), а не в ""Загрузки» каталог. Хром не было проблем. VectorVortec
Спасибо долженЯ был выбран ответ, так как вопрос задал, как это сделать в JAVASCRIPT. codehelp4

Похожие вопросы