Как сделать плагин для Google Chrome
Каждый современный браузер имеет возможность расширения функционала за счет добавления в него плагинов(расширений), и разумеется браузер Google Chrome не исключение. Более того, все плагины созданные для Chrome отлично работают в браузерах созданных на этом же движке — Blink, среди них такие как Яндекс Браузер, Microsoft Edge и Opera (версии старше 15). Таким образом можно автоматизировать рабочие процессы на сайте, добавить недостающий функционал на страницу, обрабатывать любые данные на странице и многое другое. Рассмотрим простой и быстрый вариант создания своего плагина. Для этого нам потребуется создать несколько файлов, скриптов с кодом на JavaScript, HTML, CSS и JSON.
Структура файлов
Создаем директорию NEW_Plugin, а в ней следующий перечь файлов:
manifest.json — Главный файл плагина, манифест, содержащий его описание и настройки в формате JSON, предназначенные для браузера, описывающие то, как должен работать плагин. Ниже его содержимое:
{ "name": "Название плагина", "version": "1.0", // Версия расширения. "manifest_version": 3, // Версия манифеста "action": { "default_title": "Заголовок, название плагина", // Заголовок. Его видно если навести курсор на иконку в браузере "default_icon": { // Список путей к файлам иконок плагина, которые будут отображаться в панели браузера "16": "images/icon16.png", // Путь к иконке плагина "32": "images/icon32.png", "48": "images/icon48.png", "128": "images/icon128.png" }, "default_popup": "popup.html" // Путь к HTML файлу, который отвечает за всплывающее окно настроек плагина, при нажатии на иконку плагина в браузере }, "icons": { // Список путей к файлам иконок плагина "16": "images/icon16.png", "32": "images/icon32.png", "48": "images/icon48.png", "128": "images/icon128.png" }, "permissions": [ // Настройки прав доступа плагина "storage", // Разрешено использовать Local Storage "cookies", // Разрешено работать с Cookie "notifications", // Разрешено отправлять уведомления пользователю ], "background": { // Пусть к файлу JavaScript, который будет работать в фоновом режиме и выполнять различные действий, как со страницей, так и на системном уровне браузера "service_worker": "background.js" }, "host_permissions": [ // Список доменов к которым разрешено обращаться "https://site.ru/*", // Разрешены любые запросы к указанному домену "*://*/*" ], "content_scripts": [ // Скрипты загружаемые на веб-страницах { "matches": [ "*://mail.yandex.ru/*"], // На каких доменах разрешена загрузка скриптов "js": ["js/jquery1.8.3.min.js", "js/content.js"], // JS Скрипты "css": ["css/custom.css"] // CSS Скрипты } ] } |
background.js — Файл на JavaScript, который будет работать в фоновом режиме и выполнять различные действий, как со страницей, так и на системном уровне браузера. Например, если на сайте, на котором активирован плагин, установлена политика безопасности CORS, запрещающая обращаться из JS кода загруженного на странице сайта(content.js), к другим внешним доменам, то можно обойти это ограничение, обращаясь из content.js кода не к внешним доменам напрямую, а к JS коду плагина размещенного в background.js (вызывая соответствующую функцию). А background.js, уже далее, будет работать на уровне браузера производя запрос к нужному нам внешнему домену.
// Принимает fetch запрос от content.js, обходим CORS, шлем запрос во внешний мир chrome.runtime.onMessage.addListener(function(request, sender, sendResponse) { fetch(request.input, request.init).then(function(response) { //let response = await return response.text().then(function(text) { sendResponse([{ body: text, status: response.status, statusText: response.statusText, }, null]); }); }, function(error) { sendResponse([null, error]); }); return true; //response }); |
content.js — Файл на JavaScript, который будет загружаться непосредственно на самой веб-странице, т.е. встраиваться в неё и оперировать DOM деревом, получая доступ ко всем глобальным переменным и т.д.
// Пример запроса к внешнему сайту, в обход политики CORS var url = "https://love-crm.ru/api/v1/check/status"; // URL запроса к внешнему сайту var query = {}; // Объект POST параметров, если есть var request = { // Объект содержащий настойки запроса method: "POST", mode: "cors", headers: { "Content-Type": "application/json", "Authorization": "Token " + token, "X-Secret": secret }, body: JSON.stringify(query) } fetchResource(url, request, options); // Вызов функции из background.js работающей на уровне браузера |
popup.js — Файл на JavaScript, который будет выполняться при нажатии на иконку активированного плагина в браузере. При клике на эту иконку всплывает окно плагина, как правило с его настройками. Окно плагина написано на HTML и CSS, за что отвечают соответствующие файлы popup.html и popup.css.
popup.html — Файл на HTML, который будет отображаться при нажатии на иконку активированного плагина в браузере, как правило содержит в себе форму настроек или информацию о версии плагина.
<!DOCTYPE html> <html> <head> <title>Настройки плагина</title> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <script src="popup.js"></script> <link href="popup.css" rel="stylesheet" type="text/css"> </head> <body> Тут код HTML формы настроек плагина или информация о его версии </body> </html> |
popup.css — Файл содержащий стили CSS, отвечающие за внешний вид всплывающего окна с настройками плагина.
Загрузка плагина в браузер
Для того, чтобы добавить готовый плагин в браузер, достаточно перейти в раздел основного Меню, выбрать пункт «Дополнительные инструменты», а затем «Расширения». После чего откроется страница расширений, где нужно будет нажать кнопку «Загрузить распакованное расширение», и после активировать его. После чего плагин станет активным на веб-сайтах доступ к которым указан в манифесте, а на панели появится его иконка при нажатии на которую будет всплывать окно с формой настроек из файла popup.html.
Остается только написать основной функционал плагина в файле content.js, задать перечь действий которые он будет выполнять на целевой страницы сайта.
Также на странице плагинов(расширений) в браузере, вы можете упаковать файлы плагина в один файл с расширением CRX, для его последующей передачи и распространения.
Заключение
Простая инструкция по быстрому созданию плагина для браузеров на движке Blink, в частности Google Chrome. На будущее можно сохранить получившуюся структуру в отдельной директории под название _blank, и в случае необходимости быстрого создания плагина, просто использовать её копию.
Друзья, если вам нужна помощь в разработке плагина, или необходимо написать плагин под ваши цели и задачи, обращайтесь, буду рад сотрудничеству!
Похожие записи
Оставить комментарий
Full Stack
Senior, Architect
предложить оффер
- jQuery: как получить значение атрибута?
- PHP работа с изображением, класс SimpleImage
- Интеграция с API ОСАГО сайта sravni.ru
- Комментарии на PHP, Ajax, mySQL
- PHP: Категории бесконечного уровня вложенности.
- Nginx редирект на другой сервис с сохранением URL спросил (а) Сергей
- Исполнитель пропал, почему такое случается и понять с кем работать? спросил (а) Артем
- Можно ли WordPress считать универсальным движком? спросил (а) Андрей
- Что такое самописный скрипт или CMS? спросил (а) Антон
- Как при поиске в linux используя grep, добавить исключения? спросил (а) Алексей
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Как создать Telegram-бота с авторизацией через сайт к записи
- PHP скрипт: каталог закладок на сайты к записи
- Валидация на PHP к записи
- Сколько зарабатывают в бизнесе на совместных покупках к записи
- Сколько зарабатывают в бизнесе на совместных покупках к записи
Archive
- +2024 (25)
- Ноябрь 2024 (10)
- Октябрь 2024 (8)
- Сентябрь 2024 (1)
- Август 2024 (5)
- Май 2024 (1)
- +2023 (27)
- Ноябрь 2023 (1)
- Октябрь 2023 (13)
- Сентябрь 2023 (10)
- Апрель 2023 (1)
- Март 2023 (1)
- Февраль 2023 (1)
- +2022 (21)
- Декабрь 2022 (11)
- Ноябрь 2022 (1)
- Май 2022 (2)
- Апрель 2022 (2)
- Март 2022 (3)
- Февраль 2022 (1)
- Январь 2022 (1)
- +2021 (17)
- Декабрь 2021 (5)
- Ноябрь 2021 (2)
- Июль 2021 (1)
- Июнь 2021 (2)
- Май 2021 (5)
- Апрель 2021 (1)
- Март 2021 (1)
- +2020 (20)
- Декабрь 2020 (6)
- Сентябрь 2020 (2)
- Август 2020 (1)
- Июль 2020 (2)
- Май 2020 (2)
- Апрель 2020 (2)
- Март 2020 (2)
- Февраль 2020 (1)
- Январь 2020 (2)
- +2019 (18)
- Декабрь 2019 (3)
- Ноябрь 2019 (2)
- Октябрь 2019 (2)
- Сентябрь 2019 (1)
- Август 2019 (2)
- Июль 2019 (1)
- Июнь 2019 (1)
- Апрель 2019 (2)
- Март 2019 (1)
- Февраль 2019 (3)
- +2018 (44)
- Декабрь 2018 (4)
- Ноябрь 2018 (7)
- Октябрь 2018 (8)
- Сентябрь 2018 (1)
- Август 2018 (4)
- Июль 2018 (5)
- Май 2018 (3)
- Апрель 2018 (7)
- Март 2018 (1)
- Февраль 2018 (2)
- Январь 2018 (2)
- +2017 (19)
- Декабрь 2017 (2)
- Ноябрь 2017 (1)
- Октябрь 2017 (1)
- Сентябрь 2017 (2)
- Июль 2017 (1)
- Июнь 2017 (1)
- Май 2017 (2)
- Апрель 2017 (3)
- Март 2017 (2)
- Февраль 2017 (1)
- Январь 2017 (3)
- +2016 (36)
- Декабрь 2016 (3)
- Ноябрь 2016 (3)
- Октябрь 2016 (2)
- Сентябрь 2016 (3)
- Август 2016 (7)
- Июнь 2016 (3)
- Май 2016 (3)
- Апрель 2016 (3)
- Февраль 2016 (1)
- Январь 2016 (8)
- +2015 (36)
- Ноябрь 2015 (5)
- Октябрь 2015 (4)
- Сентябрь 2015 (1)
- Август 2015 (8)
- Июнь 2015 (1)
- Май 2015 (4)
- Апрель 2015 (8)
- Март 2015 (3)
- Февраль 2015 (2)
- +2014 (26)
- Ноябрь 2014 (2)
- Октябрь 2014 (5)
- Сентябрь 2014 (6)
- Июль 2014 (1)
- Июнь 2014 (2)
- Май 2014 (3)
- Апрель 2014 (6)
- Февраль 2014 (1)
- +2013 (27)
- Декабрь 2013 (2)
- Ноябрь 2013 (1)
- Октябрь 2013 (1)
- Август 2013 (1)
- Июль 2013 (3)
- Июнь 2013 (10)
- Май 2013 (1)
- Апрель 2013 (2)
- Февраль 2013 (3)
- Январь 2013 (3)
- +2012 (41)
- Декабрь 2012 (2)
- Ноябрь 2012 (3)
- Октябрь 2012 (7)
- Сентябрь 2012 (2)
- Август 2012 (1)
- Июль 2012 (3)
- Июнь 2012 (2)
- Май 2012 (6)
- Апрель 2012 (2)
- Март 2012 (7)
- Февраль 2012 (5)
- Январь 2012 (1)
- +2011 (57)
- Декабрь 2011 (6)
- Ноябрь 2011 (2)
- Октябрь 2011 (3)
- Сентябрь 2011 (5)
- Август 2011 (4)
- Июль 2011 (3)
- Июнь 2011 (3)
- Май 2011 (3)
- Апрель 2011 (4)
- Март 2011 (10)
- Февраль 2011 (5)
- Январь 2011 (9)
- +2010 (43)
- Декабрь 2010 (7)
- Ноябрь 2010 (21)
- Октябрь 2010 (14)
- Сентябрь 2010 (1)
Свежие записи
- Интеграция платежной системы MoonPay на сайт по API 10.11.2024
- Парсер товаров с Taobao 08.11.2024
- Упаковка и минификация кода JavaScript онлайн 07.11.2024
- Как эффективно анализировать логи при DDOS атаке 07.11.2024
- Бот для автоматических заказов на OZON (плагин для Chrome) 07.11.2024