Как скачать защищенный PDF файл с Google Диска, за минуту

Chrome pdf

Добрый день! Уважаемые читатели и гости одного из крупнейших IT блогов в России Pyatilistnik.org. В прошлый раз мы с вами научились запрещать автовоспроизведение видео в браузере Chrome, так как все понимают на сколько это может раздражать, и может быть несвоевременно, на Youtube для этого была отдельная кнопка, а вот в плане всего интернета пришлось выбирать любой из понравившихся методов. Сегодня я хочу вас научить скачивать защищенный PDF файл с Google Drive (Google Диска). Под защищенным понимается, что у вас есть возможность читать его с правами только на чтение и скачать или сохранить себе на Google диск вы его не можете. Но как выяснилось все очень просто решается и уже все придумано за нас.

Постановка задачи

И так у нас с вами есть ссылка на PDF файл, который располагается на облачном хранилище Google Диск, вот пример ссылки:

https://drive.google.com/file/d/0B8pbiwdqmBuPa2xjNkItTHdWRW8/edit

Как вы можете обратить внимание, это книга "Дешифровка критской письменности (Пеластско-лезгинский язык)". Все, что вы можете сделать это вызвать панель с меню и выбрать свойства документа.

Просмотр защищенного PDF файла в Google Drive

Как видно тип документа PDF, и вы максимум можете его просматривать, так как владелец просто запретил скачивать файл. Мы с вами научимся это обходить, так как мы уже с легкостью умеем скачивать ограниченное видео с Google диска, методология будет похожа, но не полностью.

Просмотр PDF документа Google Диска в режиме чтения

Суть метода по скачиванию ограниченного PDF файла на Гугл диске

Как оказалось Гугл диск хранит все PDF файлы в виде отдельных файлов картинок и когда пользователь начинает просматривать документ, его просто собирает в веб интерфейсе, на уровне файлового хранилище, это просто картинки. Проверить это легко, вы должны открыть защищенный PDF документ, вызвать режим разработчика, через клавишу "F11" и перейдя на вкладку "Network", где после чего нужно обновить страницу с файлом. Делается это через клавишу "F5". Теперь если вы зайдете в раздел "XHR", то увидите там кучу ссылок типа "xhr". Открыв любую из них вас перекинет на страницу, которую вы уже успели промотать в книжке.

Зная факт того, что это картинки и они попадают в кэш при просмотре, мы можем их вытащить из кэша и объединить в единый PDF файл

Как ггугл диск хранит PDF файлы

Теперь, что мы делаем поэтапно:

  1. Откройте ваш защищенный PDF документ, я покажу, как это делается в Mozilla Firefox и Google Chrome
  2. Перейдите в режим разработчика
  3. Нажмите клавишу F5 для обновления страницы
  4. Полностью пролистайте весь PDF документ, все страницы. Так как они должны попасть в локальный кэш вашего браузера
  5. Выполните специальный код, который объединит все страницы в кэше в единый PDF файл и позволит его загрузить на компьютер

Текст кода для скачивания защищенного PDF файла с Google Диска

let jspdf = document.createElement("script");
jspdf.onload = function () {
let pdf = new jsPDF();
let elements = document.getElementsByTagName("img");
for (let i in elements) {
let img = elements[i];
console.log("add img ", img);
if (!/^blob:/.test(img.src)) {
console.log("invalid src");
continue;
}
let can = document.createElement('canvas');
let con = can.getContext("2d");
can.width = img.width;
can.height = img.height;
con.drawImage(img, 0, 0, img.width, img.height);
let imgData = can.toDataURL("image/jpeg", 1.0);
pdf.addImage(imgData, 'JPEG', 0, 0);
pdf.addPage();
}
pdf.save("download.pdf");
};
jspdf.src = 'https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.5.3/jspdf.debug.js';
document.body.appendChild(jspdf);

Как загрузить ограниченный PDF из Google Drive через Mozilla

  • Откройте ваш защищенный PDF документ, я покажу, как это делается в Mozilla Firefox
  • Перейдите в режим разработчика. В Mozilla Firefox это делается, через одновременное нажатие клавиш CTRL+Shift+I или вызов соответствующего меню "Веб разработка - Инструменты разработчика"

Отрываем режим разработчика в Mozilla

  • Далее нажмите клавишу F5 и обновите страницу
  • Полностью, по порядку пролистайте все страницы данного PDF файла

Просматривание PDF файла в Google Drive

Перейдите на вкладку "Консоль". Именно сюда нам нужно будет вставлять код, но по умолчанию политика безопасности Mozilla Firefox запрещает выполнение неподписанных скриптов. Чтобы это обойти вам нужно, это разрешить.

вкладка консоль в инструментах разработчика Firefox

Вам нужно ввести "разрешить вставку" и нажать Enter.

Разрешаем выполнение стороннего кода в Firefox

Теперь вставляем код. Для его выполнения нажмите одновременно CTRL и Enter.

Выполнение кода для скачивания защищенного PDF с гугл диска

Начинается процесс скачивания картинок и объединение их в единый PDF-файл.

Преобразование картинок из Google Drive в PDF файл

Через некоторое время браузер вам предложит сохранить DPF файл к вам на компьютер.

Скачивание защищенного PDF файла

Как видите я успешно загрузил ограниченный владельцем PDF документ, все прекрасно работает.

Успешно скачанный ограниченный PDF файл из гугл диска

Как загрузить ограниченный PDF из Google Drive через Chrome

  • Откройте ваш защищенный PDF документ, я покажу, как это делается в Google Chrome
  • Перейдите в режим разработчика. В Google Chrome это делается, через нажатие клавиши F11 или вызов соответствующего меню "Дополнительные - Инструменты разработчика (CTRL+SHOFT+I)"

Вызов режима разработчика в Chrome

  • Обязательно выберите режим iPad Pro для максимального разрешения и выставите масштаб 100%, в противном случае вы скачаете документ не с очень хорошим качеством. Далее нажмите клавишу F5 и обновите страницу
  • Полностью, по порядку пролистайте все страницы данного PDF файла
  • Далее перейдите на вкладку "Console"

Вызов консоли в инструментах разработчика

Вам необходимо вставить представленный выше код для скачивания ограниченного PDF файла, после чего просто нажать Enter.

Выполнение кода для скачивания защищенного PDF в Chrome

Начнется процесс сборки вашего PDF документа.

Скачивание ограниченного PDF файла из гугл диска

Через пару мгновений вы получите нужный вам PDF документ.

Успешно загруженный PDF документ

Обновление скрипта от 22.11.2024

За обновленный скрипт, спасибо подписчику Игорю.

// Создаём Trusted Types Policy (если используется Trusted Types)
const policy = trustedTypes.createPolicy(‘default’, {
createScriptURL: (url) => url
});

// Создаём элемент для загрузки библиотеки jsPDF
let jspdf = document.createElement(«script»);

// Указываем безопасный (TrustedScriptURL) источник для
jspdf.src = policy.createScriptURL(‘https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.5.3/jspdf.debug.js’);

// Когда библиотека загружена, выполняем основную логику
jspdf.onload = function () {
let pdf = new jsPDF(); // Создаём новый PDF-документ
let elements = document.getElementsByTagName(«img»); // Находим все на странице

for (let i = 0; i < elements.length; i++) {
let img = elements[i];
console.log("Processing image: ", img);

// Проверяем, чтобы источник изображения начинался с "blob:"
if (!/^blob:/.test(img.src)) {
console.log("Skipping invalid src: ", img.src);
continue;
}

// Создаём для преобразования изображения
let can = document.createElement(«canvas»);
let con = can.getContext(«2d»);
can.width = img.width;
can.height = img.height;
con.drawImage(img, 0, 0, img.width, img.height);

// Преобразуем изображение в формат Base64
let imgData = can.toDataURL(«image/jpeg», 1.0);

// Добавляем изображение в PDF
pdf.addImage(imgData, ‘JPEG’, 0, 0);

// Добавляем новую страницу только если это не последнее изображение
if (i 1) {
pdf.deletePage(totalPages); // Удаляем последнюю страницу
}

// Сохраняем PDF с именем «download.pdf»
pdf.save(«download.pdf»);
};

// Добавляем на страницу
document.body.appendChild(jspdf);

Что делать если не работает в Chrome

Тут я посоветую использовать Mozilla или же найдите версию Chrome до 100-110, главное у них отключить обновление, как вариант можно сделать из них и портативные версии.

На этом у меня все, скачивание ограниченных файлов с гугл диска через другие браузеры очень похоже, поэтому я не буду их описывать. С вами был Иван Семин, автор и создатель IT портала Pyatilistnik.org.

Оцените статью
Настройка серверов windows и linux
Добавить комментарий

  1. фыва

    Очень хочется узнать как таким образом можно скачать презентацию а не pdf документ? В презентации есть много картинок+видео и текст

  2. Иван Семин автор

    А это вызов, с вас пример ссылки

  3. Elena

    Спасибо большое!

  4. Антон

    Спасибо, очень круто, только не много качество хуже становиться

  5. Никита

    Просто шик, спасибо за подробную инструкцию! Очень пригодилось и заняло несколько минут. Качество на уровне.

  6. Юлия

    все сделала по инструкции, файл сохраняется в плохом качестве в левом углу на листе, что то с кодом не так?

  7. Иван Семин автор

    Увеличьте размер документа, поставьте 100-120%

  8. Антон

    Да ты неимоверно крут! Готов перечислить даже малость денег

  9. Иван Семин автор

    Если хотите задонатить, то на странице об авторе есть реквизиты!

  10. Степан

    А ты хороший человек!!!)))

  11. Дмитрий

    Хочется скачать вот такой документ
    _ttps://docs.google.com/spreadsheets/u/0/d/1XMyVTv5hb9-nJZhHmHASHEyFDfpDneSfqu—mSlqJcU/htmlview#
    Это гугл-таблицы. Возможно ли?

  12. Иван Семин автор

    Нет не получиться, тут нет прав на это

  13. Алексей

    Когда файл сохраняется, по низу обрезается 30% информации, по тексту это 4 строчки. От чего метод становится не рабочим, т.к. суть теряется на первом листе.

  14. Иван Семин автор

    у меня такого нет, книжка скачивается на ура

  15. Дима

    У меня не получается — я вижу XHR — отдельные страницы, образуется
    download.pdf — но он пустой — 1 страница пустая

    Google Chrome ubuntu 20.04

    Да скрипт запускается в Tampermonkey — привязанного к веб странице с книжкой в момент refresh.

    add img 0
    VM1068 userscript.html:24 invalid src
    VM1068 userscript.html:22 add img ƒ item() { [native code] }
    VM1068 userscript.html:24 invalid src
    VM1068 userscript.html:22 add img ƒ namedItem() { [native code] }
    VM1068 userscript.html:24
    add img 0
    VM943 userscript.html:24 invalid src
    VM943 userscript.html:22 add img ƒ item() { [native code] }
    VM943 userscript.html:24 invalid src
    VM943 userscript.html:22 add img ƒ namedItem() { [native code] }
    VM943 userscript.html:24 invalid src

    Navigated to _ttps://drive.google.com/file/d/0B5yKZ3bWyNe6SHB2T1BHYVdsT1k/view
    VM1027 userscript.html:22 add img 0
    VM1027 userscript.html:24

  16. Дима

    Получилось — но после некоторых усилий. На ubuntu 20.04 — у меня не работает из GOOGLE CHROME но работает из CHROMIUM и MOZILLA. Скрипт надо каждый раз руками копировать открыв инструменты разработчика и закладку консоль. Там нет надписи paste если правую кнопку мыши жать. Надо скопировать просто скрипт левой кнопкой мыши и нажать на среднюю — и RETURN. Ну конечно предварителино освежив, пролистав, перед этим настроив размер ctrl++. (извиняюсь за занудство).

  17. Ангел

    Гениально просто!
    И работает! Спасибо.

  18. Геннадий

    Виноват! Адрес страницы не гугл диск.

  19. Алекс

    Доброго времени суток. Вопрос : а есть ли скрипт , чтобы проделать ту же операцию , только с дропбокс … тоже стоит запрет на скачивание и запрет на печать… а страниц много 150+ (я их вижу по отдельности и даже номера есть… но как их в кучку собрать и автоматически ? )
    Подставлял ваш скрипт — выдает ошибку : мол дропбоксом запрещено использовать скрипты или чтото такое.
    Refused to load the script ‘(тут ваш скрипт) ‘ because it violates the following Content Security Policy directive: «script-src ‘unsafe-eval'(и далее ссылки видимо на правила сервиса)

  20. anna

    Для стандартной ориентации страниц работает супер! А для альбомной не получается ((( — обрезает.

  21. Анатолий

    Добрый день. А как excel файл скачать?

  22. Алекс

    Тоже вопрос какую функцию в код добавить, что бы альбомная ориентация получилась пдф при скачивании

  23. Алекс

    для альбомной ориентации ребят:
    pdf.addPage(», ‘landscape’);
    Вот это нужно вставить вместо
    pdf.addPage();

  24. Кирилл

    Спасибо большое очень помог

  25. Ирина

    не получается альбомный лист ввести pdf.addPage(», ‘landscape’); ошибка((
    если вводить как вы писали(с книжным вариантом) все получается.
    Спасибо

  26. Александр

    Спасибо за статью! Очень полезно.

    Есть еще вызов для Вас.
    А можно сделать тоже самое, но для произвольного сайта? Чтобы скрипт сохранял все закешированные картинки при том, что они закачиваются не в виде BLOB, а в виде обычных файлов. Например, запускаем скрипт через консоль для новостного сайта и получаем все картинки со страницы. Сейчас скрипт работает только с гугл документами, а если запустить его на другом сайте, то сформируется пустой документ.

    И второе, тоже очень важное. Можно картинки не собирать в единый PDF, а сохранить в исходном виде (JPG) отдельным файлами и без запроса на сохранение каждого файла?

    Поясню для чего это нужно. Есть защищенный онлайн просмотрщик документов, в котором сделано все, чтобы пользователь не мог скачать просматриваемый материал. Смотреть можно, скачать нет. Но, по сути, этот сервис работает точно также, как и сервис гугла из Вашей статьи. При каждом нажатии на кнопку “следующая страница”, подгружается отдельная картинка и используется кеширование. Названия картинок и адреса меняются при каждой загрузке и состоят из сотни символов. Угадать адрес картинки не получается. Можно уже загруженные картинки скачивать из кэша. Вручную я из кэша картинки смог вытащить. Но нужно как-то автоматизировать процесс. В одном документе может быть 1000 страниц. А таких документов может быть много. Сами скачанные картинки удобней хранить отдельными файлами, чтобы их можно было переименовывать, пересылать, раскладывать по папочкам итп. При этом важно сохранить очерёдность скачивания файлов и при сохранении желательно называть их 0001, 0002, 0003 итп.

    Адрес для тестирования есть, но я его не хочу публиковать в открытом доступе. Если сделать универсальный скрипт для сохранения картинок произвольного сайта, то и для своей задачи я его смогу адаптировать. Некоторый опыт в программировании есть, но на других языках.

    Я пробовал решить задачу без скриптов, с помощью утилиты просмотра кэша браузера (MZCacheView). Частично работает, но не так как надо. Копировать выбранные файлы получается. Но утилита не умеет их в нужном порядке сохранять в папку, а это важно. Оригинальные названия файлов состоят из сотен символов. Утилита обрезает название файла до какой-то длинны. У них получается одинаковое называние и тогда каждому файлу добавляется числовой индекс. Вроде бы так и надо. Но проблема в том, что файлы сохраняются в последовательности по времени закачки с точностью до секунды. В одну секунду может быть закачано несколько файлов и в результате внутри каждого секундного интервала последовательность сохраненных файлов сбивается на произвольную.

  27. Евгения

    спасибо!!!

  28. Виктор 4е

    Всё получилось, огромное спасибо!!!
    Четко и быстро расписана методика , рекомендую!

  29. Сергей

    Скачал пдф файл но он идет картинками не могу скопировать текст, как это исправить?

  30. Иван Семин автор

    Не совсем понятно, что именно за проблема опишите подробнее или сделайте скриншот

  31. Дима

    При увеличении качество текста отличное, но режет картинку, в зависимости от приближения, иногда даже пополам( А без увеличения нормально, но качество не очень… Что посоветуете?

  32. Иван Семин автор

    Даже не знаю, скиньте ссылку попробую посмотреть

  33. Саблезуб

    Спасибо! Всё отлично скачалось на Гугл Хроме! Правда мне пришлось размер исходного файла на сайте поставить на 100%, иначе более крупный размер после сохранения урезается по краям. Качество сохранённого файла очень хорошее. Чёткость картинок и текст смотрибельно/читабельно. 🙂

  34. Tiamat

    Где и как выбрать качество iPad Pro?

  35. Дмитрий

    Как скачать XLS файл ?

  36. mira

    подскажите, как скачать docx?

  37. Иван Семин автор

    Пример приведите попробую

  38. Вера

    уииии, спасибо!!!!! Так просто!!!)))) Немного с отображением больших картинок помучалась,но все получилось!!!!

  39. Иван

    Спасибо большое очень помогли!

  40. Виталий

    Благодарю, работает при масштабе 100%, больше — соответственно обрезает.
    Но при 100% читается.

  41. Дмитрий

    у меня получилось скачать качественно pdf в альбомной ориентации при такой строчке кода —
    let pdf = new jsPDF(«l», «mm», «a3»);

  42. Иван

    Вопрос владелец видит, кто у него все таки скачал файл?

  43. Иван Семин автор

    Нет

  44. мария

    здравствуйте. У меня альбомный pdf файл. Скачивает его наполовину обрезанным, пробовала ваш код и правки которые люди советовали в комментариях. С вашим кодом — скачивает обрезанным. Если вставлять правки — вообще ошибку выдает. В чем может быть дело?

  45. Игорян

    Здравствуйте! Такая же проблема, как у Марии. Скачивается обрезанным, если альбомная ориентация и требуется приближение, так как требуется хорошее качество. Правки из комментов тоже не помогают.
    Если не приближать, нормально скачивается, но очень некачественно.

  46. Ника

    КАЙФ!!!!!

    Спасибо тебе мил человек! Дай Бог здоровья и денег побольше.

  47. Вероника

    Здравствуйте, умоляю Вас, помогите пожалуйста!
    Если вас не затруднит, подскажите, каким образом можно скачать защищенный docs. файл или хотя бы скопировать текст? Т.Т
    сам файл лежит в «гугл документах», вот ссылка:
    _ttps://docs.google.com/document/d/1WauyboAQIE0mC1iUAcpHKXKd3AT64XV6nKntchGLaXw/edit

  48. Иван Семин автор

    Вероника, вот инструкция, как это сделать

  49. Владимир

    у меня качество получилось хуже, чем на скриншоте.Если увеличивать масштаб, то скачивается только видимая на экране часть страницы/ Причем, в мозилле скрипт вообще не заработал, только в Опере.

  50. Igor

    Попробовал данный способ в отношении файла на _docs.google.com
    К сожалению не сработал — файл сохраняет, но это одностраничный пустой pdf файл.
    Будем искать…

  51. Георгий

    для альбомного размера достаточно изменить вначале
    let pdf = new jsPDF();
    на
    let pdf = new jsPDF(‘landscape’, ‘pt’, ‘a4’);

  52. MDenis22

    Если разобраться, то в этом примере выкачивается не сам PDF-файл, а сканы всех его страниц, в том виде, как их генерирует браузер. И текст, который можно было выделить при просмотре оригинала перестает быть текстом и становится картинкой.
    Так что если хочется сохранить именно текст, то CTRL+S и скачиваем именно веб-страницу, из которой потом можно надергать текст. Что бы не пользоваться различными распознователями текста.

  53. Дарья

    Добрый день, спасибо все получилось. Однако файл хотелось бы скачать в альбомном формате. Советы комментаторов не помогают или я не правильно и не туда из ввожу. Может кто то может поделится отдельным скриптом на вертикальные листы?

  54. Светлана

    Добрый день. Спасибо большое! Все получилось. Для личной домашней печати сойдет.

  55. Александр

    Спасибо!

  56. Игорь

    Добрый день!
    А как насчет смешанных страниц А4 и А3

  57. Дарья

    Пожалуйста, помогите перевернуть станицы горизонтально. У меня не выходит((((
    Все советы из комментариев перепробовала, не исключаю то дело во мне

  58. Кра

    Красаавчик, человечище!
    Но, нужно повер поинт еще….

  59. Малика

    Спасибо огромное! Получилось с первого раза!

  60. Серый Волк

    Новый скрипт, который сам подбирает масштаб и ориентацию, сам скроллит перед скачиванием, сохраняет файл в максимальном качестве. Не увеличивайте масштаб браузера больше 150%, скрипт не сработает

    let jspdf = document.createElement(«script»);
    jspdf.onload = function () {
    let pdfDocumentName = «Document»;
    let doc;

    function generatePDF (){
    let imgTags = document.getElementsByTagName(«img»);
    let checkURLString = «blob:https://drive.google.com/«;
    let validImgTagCounter = 0;
    for (i = 0; i img.naturalHeight){
    //console.log(«Landscape»);
    orientation = «l»;
    //ratio = img.naturalWidth/img.naturalHeight
    }else {
    //console.log(«Portrait»);
    orientation = «p»;
    //ratio = img.naturalWidth/img.naturalHeight
    }

    let scalefactor = 1.335;
    let pageWidth = img.naturalWidth * scalefactor;
    let pageHeight = img.naturalHeight * scalefactor;
    //let imagexLeft = (pageWidth — img.naturalWidth)/2;
    //let imagexTop = (pageHeight — img.naturalHeight)/2;
    if (validImgTagCounter === 1){
    doc = new jsPDF({
    orientation: orientation,
    unit: «px»,
    format: [pageWidth, pageHeight],
    });
    doc.addImage(imgDataURL, «PNG», 0, 0, img.naturalWidth, img.naturalHeight);
    }else{
    doc.addPage([pageWidth, pageHeight] , orientation);
    doc.addImage(imgDataURL, «PNG», 0, 0, img.naturalWidth, img.naturalHeight);
    }
    }
    }

    pdfDocumentName = pdfDocumentName + «.pdf»;
    doc.save(pdfDocumentName);
    }

    let allElements = document.querySelectorAll(«*»);
    let chosenElement;
    let heightOfScrollableElement = 0;

    for (i = 0; i =allElements[i].clientHeight){
    if (heightOfScrollableElement chosenElement.clientHeight){
    console.log(«Auto Scroll»);

    let scrollDistance = Math.round(chosenElement.clientHeight/2);
    //console.log(«scrollHeight: » + chosenElement.scrollHeight);
    //console.log(«scrollDistance: » + scrollDistance);

    let loopCounter = 0;
    function myLoop(remainingHeightToScroll, scrollToLocation) {
    loopCounter = loopCounter+1;
    console.log(loopCounter);

    setTimeout(function() {
    if (remainingHeightToScroll === 0){
    scrollToLocation = scrollDistance;
    chosenElement.scrollTo(0, scrollToLocation);
    remainingHeightToScroll = chosenElement.scrollHeight — scrollDistance;
    }else{
    scrollToLocation = scrollToLocation + scrollDistance ;
    chosenElement.scrollTo(0, scrollToLocation);
    remainingHeightToScroll = remainingHeightToScroll — scrollDistance;
    }

    if (remainingHeightToScroll >= chosenElement.clientHeight){
    myLoop(remainingHeightToScroll, scrollToLocation)
    }else{
    setTimeout(function() {
    generatePDF();
    }, 1500)
    }

    }, 500)
    }
    myLoop(0, 0);

    }else{
    console.log(«No Scroll»);
    setTimeout(function() {
    generatePDF();
    }, 1500)
    }

    };
    jspdf.src = ‘https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.5.3/jspdf.debug.js’;
    document.body.appendChild(jspdf);

  61. Джунайд

    Спасибо! Получилось не с первого раза. По сему совет всем чайникам, как и я, внимательно смотрите Видео-инструкцию. При копировании вызывайте контекстное меню правой кнопкой мыши и там нажмите Копировать. У меня при использовании Кнтрол+с, фишка не срабатывала. Всем удачи!

  62. Jen

    Есть ли такая инструкция для яндекс диска? По аналогии ничего не выходит, скачивается пустой одностраничный pdf

  63. Кира

    Кошмар( полдня ковыряюсь с этой инструкцией, либо не влезает на лист, либо вся скомканная в углу листа, и не прочесть. Как просто вытащить эти изображения из «блоба»? ПДФку я потом и так могу сделать.

  64. Елена

    Здравствуйте. К сожалению, нельзя скачать файл((( он как сохраняется в формате ПДФ, но не открывается (только через браузер), так и после всех ваших манипуляций сохраняется как даунлод пдф, но открывается так же, только через браузер(((( Памамгити….

  65. Тамара

    Огромная, просто нереальная благодарность за рабочий инструмент!

  66. Елена

    Uncaught SyntaxError: unexpected token: identifier
    Вот такая запись выходит, когда нажимаю на Enter
    Что делать дальше?

  67. Виктор

    Добрый день, при попытке скачивания вылетает эта ошибка «This document requires ‘TrustedScriptURL’ assignment»
    Это как-то можно обойти?
    Заранее спасибо за ответ

  68. Ольга

    Спасибо.
    Пользуюсь уже несколько недель.
    Только теперь в Mozilla приходится печатать

    разрешить вставку;

    Иначе не срабатывает

  69. Matkarimov

    Раньше работал. Теперь не работает что-то изменилась походу. Можете помочь ???

  70. Иван Семин автор

    Попробуйте с Mozilla

  71. Владислав

    Гениально!!!. Дай Бог тебе здоровья, выручил оч. сильно. Правда в Гугле не получилось, пришлось Мозилу ставить. Правда при нормальном качестве правый край документа был слегка обрезан, не все было видно. При худшем качестве все вошло. Но все же читать можно. Еще раз спасибо

  72. Анастасия

    Добрый день! Ранее скрипт работал, сейчас не удается скачать файл. Выдает
    This document requires ‘TrustedScriptURL’ assignment.
    Uncaught TypeError: Failed to set the ‘src’ property on ‘HTMLScriptElement’: This document requires ‘TrustedScriptURL’ assignment.

  73. Иван Семин автор

    Попробуйте выполнить в Mozilla

  74. Прохор

    огромная благодарность за скрипт. все сработало, но только в FireFox

  75. Angex

    Спасибо! Это а потрясающе, вы меня сильно выручили

  76. Лерика

    Дай вам Бог здоровья, добрый человек. Что бы я без вас делала…))
    В Хроме не сработало, установила Мозиллу и все прошло как по маслу.

  77. Даниил

    доброго дня.
    ошибка вышла
    VM 641:23 Uncaught TypeError: Failed to set the ‘src’ property on ‘HTMLScriptElement’: This document requires ‘TrustedScriptURL’ assignment.

  78. Всеволод Бухаров

    Спасибо, очень выручили.

  79. Michail

    VM818:23 This document requires ‘TrustedScriptURL’ assignment. а если такое что делать?

  80. Игорь

    Спасибо за скрипт! Я попробовал в google chrome — сейчас уже не работает. Нужно было сначало в консоль ввести команду: allow pasting
    А потом вставлять скрипт. Я скрипт исправил с помощью ИИ:

    // Создаём Trusted Types Policy (если используется Trusted Types)
    const policy = trustedTypes.createPolicy(‘default’, {
    createScriptURL: (url) => url
    });

    // Создаём элемент для загрузки библиотеки jsPDF
    let jspdf = document.createElement(«script»);

    // Указываем безопасный (TrustedScriptURL) источник для
    jspdf.src = policy.createScriptURL(‘https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.5.3/jspdf.debug.js’);

    // Когда библиотека загружена, выполняем основную логику
    jspdf.onload = function () {
    let pdf = new jsPDF(); // Создаём новый PDF-документ
    let elements = document.getElementsByTagName(«img»); // Находим все на странице

    for (let i = 0; i < elements.length; i++) {
    let img = elements[i];
    console.log("Processing image: ", img);

    // Проверяем, чтобы источник изображения начинался с "blob:"
    if (!/^blob:/.test(img.src)) {
    console.log("Skipping invalid src: ", img.src);
    continue;
    }

    // Создаём для преобразования изображения
    let can = document.createElement(«canvas»);
    let con = can.getContext(«2d»);
    can.width = img.width;
    can.height = img.height;
    con.drawImage(img, 0, 0, img.width, img.height);

    // Преобразуем изображение в формат Base64
    let imgData = can.toDataURL(«image/jpeg», 1.0);

    // Добавляем изображение в PDF
    pdf.addImage(imgData, ‘JPEG’, 0, 0);

    // Добавляем новую страницу только если это не последнее изображение
    if (i 1) {
    pdf.deletePage(totalPages); // Удаляем последнюю страницу
    }

    // Сохраняем PDF с именем «download.pdf»
    pdf.save(«download.pdf»);
    };

    // Добавляем на страницу
    document.body.appendChild(jspdf);