|
8 / 10 / 8
Регистрация: 30.12.2013
Сообщений: 577
|
|
[Критика] Привязка к железу08.11.2014, 22:48. Показов 10236. Ответов 30
Метки нет (Все метки)
Ребят привет, хотел бы чтобы вы мне сказали какие есть уязвимости в моей ТРУ привязке
![]() Прикрепил архив, в нем:
На самом хостинге уже есть эти же файлы, поэтому не стоит создавать локальный сервер. Я учел, то что реверсер может первым делать блокануть host и поэтому сделал проверку нету ли в host'e моего сервера... Пожалуйста скажите какие есть в моей привязке дыры. И если вас не затруднит, как из исправить.
0
|
|
| 08.11.2014, 22:48 | |
|
Ответы с готовыми решениями:
30
Критика - Способ привязки к железу Привязка приложения к железу Привязка к железу, как сделать, чтобы не слетала после переустановки Windows? |
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,231
|
||||||
| 08.11.2014, 23:28 | ||||||
|
Все, что надо будет сделать чтобы сломать ваше приложение:
1. Открыть его dotPeek-ом. 2. Вставить вот здесь:
Добавлено через 4 минуты Даже если обфусцировать (хотя нет опыта в защите .net app), то строковые литералы все равно видно в plain, и можно будет найти по слову "Активировано" код проверки.
0
|
||||||
|
8 / 10 / 8
Регистрация: 30.12.2013
Сообщений: 577
|
||
| 08.11.2014, 23:31 [ТС] | ||
|
И как избавится от первой дыры которые вы нашли? Каким образом его защитить, если софт будет защищен обфукатором.
0
|
||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,231
|
|
| 09.11.2014, 00:16 | |
|
+ еще варианты:
2. Можно взять откуда-то валидное значение ключа и в GET вторым параметром всегда его пихать. То есть также всегда будет возвращать true. 3. Если нету ключа, можно dos-ить/брутфорсить этот url, пока он не вернет true и использовать полученное значение ключа. Используемый алгоритм хеширования опять же можно достать из исходника. Вся защита упирается в защиту исходного кода вашего клиента. А для managed app, как мне кажется, защиту трудно реализовать. Если только в очень больших проектах, где много кода, и с хорошими инструментами для обфускации. Добавлено через 23 минуты Как вариант усиления защиты: реализовать некоторый функционал в dll и при запуске приложения проверять большее количество уникальных параметров компьютера и приложения (какой-нибудь уникальный id дистрибутива, mac адрес, размер физической памяти, etc) => если условие выполняется, то скачивать недостающую библиотеку и загружать в домен приложения, без выгрузки в файловую систему. При этом было бы неплохо, чтобы на сервере хранились параметры ОС, и сборка была бы уже нативная, то есть не IL-code, а уже код платформы. Получается этакое работающее только онлайн приложение. + Если копать глубже, то, теоретически, можно ведь подменять адреса dns-ов, которые будут возвращать IP-адреса серверов злоумышленника, которые, в свою очередь, будут возращать всегда true.
1
|
|
|
8 / 10 / 8
Регистрация: 30.12.2013
Сообщений: 577
|
||
| 09.11.2014, 00:20 [ТС] | ||
|
0
|
||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,231
|
|
| 09.11.2014, 00:22 | |
|
В VS => Создать новый проект (тип - Class Library - библиотека классов).
1
|
|
|
8 / 10 / 8
Регистрация: 30.12.2013
Сообщений: 577
|
||
| 09.11.2014, 00:28 [ТС] | ||
|
0
|
||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,231
|
|
| 09.11.2014, 00:39 | |
|
Все просто:
0
|
|
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,231
|
|
| 09.11.2014, 00:44 | |
|
Когда пишешь свой код, то обычно добавляешь в References, подключать нужные namespace из этой библиотеки, ну и затем можно использовать описанные в ней классы. Вам же нужно будет по-другому сделать.
Как вариант: у класса Assembly есть событие AssemblyResolve, которое возникает тогда, когда приложение не может загрузить в свой домен приложения другую сборку. Вот в этом-то событии и загружайте эту сборку с вашего сервера.
1
|
|
|
|
|||||||
| 09.11.2014, 00:46 | |||||||
1
|
|||||||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,231
|
|
| 09.11.2014, 00:47 | |
|
То есть в ссылках сборка висеть должна, а по факту с дистрибутивом поставляться не будет.
Добавлено через 1 минуту * AppDomain.AssemblyResolve event
1
|
|
|
8 / 10 / 8
Регистрация: 30.12.2013
Сообщений: 577
|
|
| 09.11.2014, 00:56 [ТС] | |
|
0
|
|
|
|
||
| 09.11.2014, 01:01 | ||
|
0
|
||
|
|
|
| 09.11.2014, 01:15 | |
|
FreeZon, вот архив самой dll. Ну а алгоритм создания ключа - то же самое, только наоборот.
1
|
|
|
Ушел с форума
|
||
| 09.11.2014, 09:27 | ||
|
Я знаю очень мало программ, которые ее используют. Потому что это проблемы с клиентами: сменил диск - проблемы, вставил другую сетевую карту - проблемы, запустил программу на виртуалке - проблемы, и т.д.
1
|
||
|
41 / 37 / 9
Регистрация: 01.02.2014
Сообщений: 825
|
|
| 09.11.2014, 17:01 | |
|
Убежденный, что вы предлагаете? Писать и делиться?
0
|
|
|
Ушел с форума
|
|
| 09.11.2014, 17:58 | |
|
Я предлагаю вообще не заморачиваться.
0
|
|
|
8 / 10 / 8
Регистрация: 30.12.2013
Сообщений: 577
|
||
| 09.11.2014, 18:35 [ТС] | ||
|
0
|
||
|
286 / 192 / 56
Регистрация: 25.12.2012
Сообщений: 640
|
||
| 09.11.2014, 18:51 | ||
|
Можно привязать к процессору (cpuid), уж его то редко кто меняет. И в принципе можно обойтись без dll, рефлексия в .net позволяет юзать asm вставки.
0
|
||
| 09.11.2014, 19:40 | |
|
FreeZon,
Через реестр можно изменить путь к hosts
0
|
|
| 09.11.2014, 19:40 | |
|
Помогаю со студенческими работами здесь
20
Привязка к железу Привязка к железу
Привязка к железу Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|