stihl не предоставил(а) никакой дополнительной информации.
Если вы работаете с картами и шопами, то каждый раз сталкиваетесь с необходимостью подмены отпечатков.
Сегодня поговорим о Canvas, так как это один из важнейших параметров влияющих на успешность вбива.
Цифровой отпечаток с использованием Canvas — это один из методов получения цифрового отпечатка устройства для отслеживания онлайн-пользователей, позволяющий веб-сайтам идентифицировать и отслеживать посетителей с помощью HTML5 Canvas без использования cookie-файлов или других подобных средств.
Большинство антидетект-браузеров представленых на рынке предлагают вам менять отпечаток Canvas на сгенерированый, что делает его на 100% уникальным - а это соответственно фрод! Потому что уникальных отпечатков не бывает - это аномалия.
Соответственно для прохождения антифрод-систем, нам нужен настоящий (не сгенерированый) канвас.
Рассмотрим способ подмены данного отпечатка без антидетект-браузера.
Для примера рассмотрим перенос канваса с одного нашего браузера в другой на странице Для просмотра ссылки Войдиили Зарегистрируйся
Понадобится расширение Для просмотра ссылки Войдиили Зарегистрируйся.
Устанавливайте с официального магазина Chrome.
Для корректной работы обязательно включаем режим разработчика.
Заходим с браузера например Edge на browserleaks.com/canvas
Открываем консоль (F12)
Пишем allow pasting
И вставляем следующий код
Копируем наш канвас, его будем переносить в другой браузер (как это использовать на реальных примерах распишу ниже)
После того как у нас есть нужный канвас, переходим в Chrom`e на browserleaks
Открываем расширение Tampermonkey и нажимаем создать новый скрипт
В открывшемся окне пишем следующий код
Нажимаем Сохранить
Готово, проверяем - канвас поменялся на нужный нам.
Теперь касательно реального применения.
Берём кусок кода, благодаря которому и формируется наш канвас
Далее, закидываем этот код на любой свой веб-ресурс и включаем логирование этого отпечатка
Покупаем нужное количество трафика на наш веб-ресурс
По итогу менее чем за сутки получаем неограниченое количество реальных canvas-отпечатков, а так же любых других отпечатков, таких как WebGL, audio и т.д, которые подменяются таким же способом.
Используем их под свои цели или же открываем магазин отпечатков, для тех, кому самому это делать лень)
!Важный момент! Код выше подойдет соотвественно только для browserleaks - он приведен для примера. Таким же образом вы собираете отпечатки для ресурса, который нужен именно вам, вставляя код с нужного вам ресурса!
Для затравки стоит отметить, что данное расширение так же работает на IOS, и, если вы включите голову, то в любой момент ваш старый айфон - становится новым айфоном.
Информация для статьи взята из открытых источников в том числе Youtube-канала VektorT13.
Сегодня поговорим о Canvas, так как это один из важнейших параметров влияющих на успешность вбива.
Цифровой отпечаток с использованием Canvas — это один из методов получения цифрового отпечатка устройства для отслеживания онлайн-пользователей, позволяющий веб-сайтам идентифицировать и отслеживать посетителей с помощью HTML5 Canvas без использования cookie-файлов или других подобных средств.
Большинство антидетект-браузеров представленых на рынке предлагают вам менять отпечаток Canvas на сгенерированый, что делает его на 100% уникальным - а это соответственно фрод! Потому что уникальных отпечатков не бывает - это аномалия.
Соответственно для прохождения антифрод-систем, нам нужен настоящий (не сгенерированый) канвас.
Рассмотрим способ подмены данного отпечатка без антидетект-браузера.
Для примера рассмотрим перенос канваса с одного нашего браузера в другой на странице Для просмотра ссылки Войди
Понадобится расширение Для просмотра ссылки Войди
Устанавливайте с официального магазина Chrome.
Для корректной работы обязательно включаем режим разработчика.
Заходим с браузера например Edge на browserleaks.com/canvas
Открываем консоль (F12)
Пишем allow pasting
И вставляем следующий код
const canvas = document.createElement('canvas');canvas.width = 220;canvas.height = 30;const ctx = canvas.getContext('2d');// Исходный текст, как на browserleaksconst txt = "BrowserLeaks,com <canvas> 1.0";// Настройки текста и фонаctx.textBaseline = "top";ctx.font = "14px 'Arial'";ctx.textBaseline = "alphabetic";// Заливка оранжевым прямоугольникомctx.fillStyle = "#f60";ctx.fillRect(125, 1, 62, 20);// Синий текстctx.fillStyle = "#069";ctx.fillText(txt, 2, 15);// Полупрозрачный зелёный текст поверхctx.fillStyle = "rgba(102, 204, 0, 0.7)";ctx.fillText(txt, 4, 17);// Получение base64 строки PNGconst dataUrl = canvas.toDataURL();// Вывод результатаconsole.log('Canvas base64:\n', dataUrl);
Копируем наш канвас, его будем переносить в другой браузер (как это использовать на реальных примерах распишу ниже)
После того как у нас есть нужный канвас, переходим в Chrom`e на browserleaks
Открываем расширение Tampermonkey и нажимаем создать новый скрипт
В открывшемся окне пишем следующий код
// ==UserScript==// @Name Canvas Fingerprint Spoofer (Browserleaks)// @namespace Для просмотра ссылки Войди или Зарегистрируйся @version 1.0// @description Подмена Canvas Fingerprint на сайте browserleaks.com/canvas (возвращает фиксированный base64-хэш вместо реального)// @author Ваше имя// @match Для просмотра ссылки Войди или Зарегистрируйся @Run-at document-start// @Grant none// ==/UserScript==(function() { 'use strict'; // Задаем фиксированный canvas-отпечаток в формате base64 (PNG изображение). // Ниже строка содержит данные PNG 300x150 px с градиентом (красный->синий) закодированные в base64. // Вы можете заменить FAKE_IMAGE_DATA_URL на свою строку "data:image/png;base64,...". const FAKE_IMAGE_DATA_URL = ""; // Перехватываем HTMLCanvasElement.toDataURL чтобы всегда возвращать наш фиксированный base64 const originalToDataURL = HTMLCanvasElement.prototype.toDataURL; HTMLCanvasElement.prototype.toDataURL = function(...args) { // Можно добавить проверку типа изображения, но здесь для простоты игнорируем аргументы return FAKE_IMAGE_DATA_URL; }; // Перехватываем HTMLCanvasElement.toBlob для случая, если страница запросит Blob вместо data URL const originalToBlob = HTMLCanvasElement.prototype.toBlob; HTMLCanvasElement.prototype.toBlob = function(callback, type, quality) { // Декодируем нашу base64-строку в бинарный массив try { const base64Data = FAKE_IMAGE_DATA_URL.split(',')[1]; // отделяем часть после "base64," const binaryStr = atob(base64Data); const len = binaryStr.length; const bytes = new Uint8Array(len); for (let i = 0; i < len; i++) { bytes = binaryStr.charCodeAt(i); } const blob = new Blob([bytes], { type: "image/png" }); // Вызываем колбэк, передавая Blob фиктивного изображения if (typeof callback === 'function') { callback(blob); } } catch(e) { // В случае ошибки вызовем оригинальный метод (на всякий случай) console.error('CanvasSpoof: toBlob error, calling original', e); return originalToBlob.call(this, callback, type, quality); } }; // Перехватываем CanvasRenderingContext2D.getImageData, чтобы при попытке чтения пикселей вернуть фиктивные данные const originalGetImageData = CanvasRenderingContext2D.prototype.getImageData; CanvasRenderingContext2D.prototype.getImageData = function(x, y, width, height) { try { // Создаем пустой ImageData заданных размеров, заполненный нулями (прозрачный черный) // Здесь можно заполнить данными, соответствующими нашему изображению, // но для простоты возвращаем пустые/чёрные пиксели одинаково каждый раз. const fakeData = new Uint8ClampedArray(width * height * 4); // (По желанию можно нарисовать в fakeData какой-то паттерн, чтобы fingerprint был не нулевой) return new ImageData(fakeData, width, height); } catch(e) { console.error('CanvasSpoof: getImageData error, calling original', e); // Если что-то пошло не так, отдаем оригинальные данные (может выдать реальный отпечаток!) return originalGetImageData.call(this, x, y, width, height); } }; // Перехватываем OffscreenCanvas.convertToBlob, чтобы возвратить Blob от нашего изображения (если OffscreenCanvas будет использован) if (typeof OffscreenCanvas !== 'undefined') { const originalConvertToBlob = OffscreenCanvas.prototype.convertToBlob; OffscreenCanvas.prototype.convertToBlob = function(...args) { // Создаем Blob из фиксированных данных и возвращаем Promise.resolve(blob) try { const base64Data = FAKE_IMAGE_DATA_URL.split(',')[1]; const binaryStr = atob(base64Data); const len = binaryStr.length; const bytes = new Uint8Array(len); for (let i = 0; i < len; i++) { bytes = binaryStr.charCodeAt(i); } const blob = new Blob([bytes], { type: "image/png" }); return Promise.resolve(blob); } catch(e) { console.error('CanvasSpoof: convertToBlob error, calling original', e); return originalConvertToBlob.apply(this, args); } }; } // Функция для применения патчей во внешнем (iframe) окне function patchCanvasInWindow(win) { try { if (!win || win.HTMLCanvasElement === undefined) return; // Переназначаем методы в контексте данного окна (iframe) win.HTMLCanvasElement.prototype.toDataURL = HTMLCanvasElement.prototype.toDataURL; win.HTMLCanvasElement.prototype.toBlob = HTMLCanvasElement.prototype.toBlob; win.CanvasRenderingContext2D.prototype.getImageData = CanvasRenderingContext2D.prototype.getImageData; if (win.OffscreenCanvas) { win.OffscreenCanvas.prototype.convertToBlob = OffscreenCanvas.prototype.convertToBlob; } } catch(e) { console.error("CanvasSpoof: error patching iframe window:", e); } } // Наблюдаем за добавлением iframe в документ, чтобы патчить canvas внутри него const observer = new MutationObserver(function(mutations) { for (const mutation of mutations) { for (const node of mutation.addedNodes) { if (node.tagName && node.tagName.toLowerCase() === 'iframe') { // Как только iframe добавлен в DOM, пытаемся применить патч try { patchCanvasInWindow(node.contentWindow); } catch(e) { /* возможноiframe не готов*/ } // Также на событие load применяем патч (на случай, если документ внутри загрузился/перезагрузился) node.addEventListener('load', function() { patchCanvasInWindow(node.contentWindow); }); } } } }); observer.observe(document.documentElement, { childList: true, subtree: true }); // Если к моменту запуска скрипта iframe уже существует в разметке: document.querySelectorAll('iframe').forEach(iframe => { patchCanvasInWindow(iframe.contentWindow); iframe.addEventListener('load', function() { patchCanvasInWindow(iframe.contentWindow); }); }); // Готово: теперь любые попытки получить данные canvas получат фиктивное изображение})();
Нажимаем Сохранить
Готово, проверяем - канвас поменялся на нужный нам.
Теперь касательно реального применения.
Берём кусок кода, благодаря которому и формируется наш канвас
Далее, закидываем этот код на любой свой веб-ресурс и включаем логирование этого отпечатка
Покупаем нужное количество трафика на наш веб-ресурс
По итогу менее чем за сутки получаем неограниченое количество реальных canvas-отпечатков, а так же любых других отпечатков, таких как WebGL, audio и т.д, которые подменяются таким же способом.
Используем их под свои цели или же открываем магазин отпечатков, для тех, кому самому это делать лень)
!Важный момент! Код выше подойдет соотвественно только для browserleaks - он приведен для примера. Таким же образом вы собираете отпечатки для ресурса, который нужен именно вам, вставляя код с нужного вам ресурса!
Для затравки стоит отметить, что данное расширение так же работает на IOS, и, если вы включите голову, то в любой момент ваш старый айфон - становится новым айфоном.
Информация для статьи взята из открытых источников в том числе Youtube-канала VektorT13.