Русский
Русский
English
Статистика
Реклама

Как обойти ограничение браузера и прикрепить сразу два файла и более мультидобавление файлов

Привет, Хабр!

Давайте решим нетривиальную задачу. Представьте, что вам нужно скачать данные через интерфейс элементарным способом, например, кликнуть по кнопке Скачать фаилы.

Возьмём по умолчанию Chrome v.88. Задача звучит так:

  • Сгенерировать файлы на стороне клиента.
  • Скачать все сгенерированные файлы одним кликом.

Это может быть всё что угодно: кучка бинарников, большие архивы с бэкапами, галерея картинок и прочее. Мы же будем говорить именно о механизме скачивания как таковом, поэтому в качестве примера возьмём скачивание текста и картинок.


Само собой, можно решить такую задачу, просто сжав все нужные файлы в один ZIP-архив, а потом уже скачать его. Выходит, пользователь скачает единый файл, который потом самостоятельно разархивирует. Например, можно использовать библиотеку jszip, которая позволяет скачивать набор файлов, сжав их.

Вот небольшой пример скачивания с предварительным сжатием из документации:

var zip = new JSZip();zip.file("Hello.txt", "Hello World\n");var img = zip.folder("images");img.file("smile.gif", imgData, {base64: true}); zip.generateAsync({type:"blob"}).then(function(content) {// see FileSaver.jssaveAs(content, "example.zip"); });

А где тут нетривиальность? спросите вы. И будете правы. А если речь идёт об одновременном скачивании с сайта двух, трёх или десяти файлов? Например: есть лист в селекте, в котором можно выбрать определённое количество файлов для скачивания. Введём дополнительное условие: у пользователя нет установленного архиватора, поэтому вариант со сжатием в архив отбрасываем. Как решить такую задачу?

Сначала подготовим браузер. Chrome по умолчанию запрещает скачивать мультифайлы. Это сделано в целях безопасности. Поэтому эту функцию надо сначала разблокировать в настройках браузера:

  1. Заходим в настройки сайтов: chrome://settings/content.
  2. Переходим в доступ дополнительных прав (Additional permissions).
  3. Выбираем Automatic downloads.
  4. Добавляем необходимый сайт в категорию Allow.




Отлично, теперь ваш браузер стал менее безопасным позволяет скачивать на конкретном сайте сразу несколько файлов.

Подход #1 FileReader


Первый подход рассмотрим на примере генерации файлов с помощью FileReader и API для чтения base64. Отмечу сразу, что у FileReader довольно обширное API, поэтому выбирайте то, что больше нравится: text, arrayBuffer или binaryString.

(function () {  const button = document.getElementById("download_with_reader");  const content = ["content-1", "content-2", "content-3"];    const createLink = () => {    let link = document.createElement('a');    link.download = 'hello.txt';    return link;  }    const generateBlob = () => {    for (const [index, value] of content.entries()) {      const blob = new Blob([value], { type: "text/plain" });      download(blob, index);    }  }  const download = (blob, index) => {    const link = createLink();    let reader = new FileReader();    reader.readAsDataURL(blob);    reader.onload = function () {      link.href = reader.result;      link.download = `content-${index+1}.txt`;      link.click();    }  }    button.addEventListener("click", generateBlob);}) ();

[код на Gitlab]

Подход #2 createObjectURL


А ещё можно использовать createObjectURL он позволяет хранить File-объекты или Blob-объекты.

(function () {  const button = document.getElementById("download_with_url_object");  const content = ["content-1", "content-2", "content-3"];    const createLink = () => {    let link = document.createElement('a');    link.download = 'hello.txt';    return link;  }  const generateBlob = () => {    for (const [index, value] of content.entries()) {      const blob = new Blob([value], { type: "text/plain" });      download(blob, index);    }  }  const download = (blob, index) => {    const link = createLink();    link.href = URL.createObjectURL(blob);    link.download = `content-${index+1}.txt`;    link.click();    URL.revokeObjectURL(link.href);  }   button.addEventListener("click", generateBlob);}) ();

[код на Gitlab]

Подход #3 Скачивание по URL


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

(function () {(function () {  const button = document.getElementById("download_with_request");  const urls = ["images/image-1.jpg", "images/image-2.jpg", "images/image-3.jpg"];    const delay = () => new Promise(resolve => setTimeout(resolve, 1000));    const downloadWithRequest = async () => {    for await (const [index, url] of urls.entries()) {      await delay();      const link = document.createElement("a");      link.href = url;      link.download = `image-${index+1}`;      link.click();    }  }    button.addEventListener("click", downloadWithRequest);}) ();

[код на Gitlab]

Итого


Вот три довольно простых способа, с помощью которых можно одновременно скачать несколько файлов с сайта и сделать это быстро. Главное включите нужные разрешения для конкретного сайта, а затем выбирайте способ по душе.
Источник: habr.com
К списку статей
Опубликовано: 03.03.2021 16:23:30
0

Сейчас читают

Комментариев (0)
Имя
Электронная почта

Блог компании яндекс.практикум

Занимательные задачки

Javascript

Google chrome

Браузеры

Яндекс.практикум

Скачивание файлов

Категории

Последние комментарии

  • Имя: Макс
    24.08.2022 | 11:28
    Я разраб в IT компании, работаю на арбитражную команду. Мы работаем с приламы и сайтами, при работе замечаются постоянные баны и лаги. Пацаны посоветовали сервис по анализу исходного кода,https://app Подробнее..
  • Имя: 9055410337
    20.08.2022 | 17:41
    поможем пишите в телеграм Подробнее..
  • Имя: sabbat
    17.08.2022 | 20:42
    Охренеть.. это просто шикарная статья, феноменально круто. Большое спасибо за разбор! Надеюсь как-нибудь с тобой связаться для обсуждений чего-либо) Подробнее..
  • Имя: Мария
    09.08.2022 | 14:44
    Добрый день. Если обладаете такой информацией, то подскажите, пожалуйста, где можно найти много-много материала по Yggdrasil и его уязвимостях для написания диплома? Благодарю. Подробнее..
© 2006-2024, personeltest.ru