Blog. Just Blog

Быстрый поиск

Введите фрагмент названия статьи для поиска

Декомпиляция CHM-файлов на Ассемблере

11.01.2025 | Категория: Образ мышления: Assembler | Автор: ManHunter

Декомпиляция CHM-файлов на Ассемблере

CHM-файлы, как правило, содержат в себе справочную документацию в формате HTML, скомпилированную и сохраненную с помощью сжатия LZX. Справочный файл может также включать в себя содержание, предметный указатель, базу для полнотекстового поиска по страницам, а также файлы изображений, скрипты, таблицы стилей и даже вложенные архивы. Чтобы извлечь все эти данные из CHM-файла, его надо декомпилировать. Об этом и будет сегодняшняя статья.

Читать статью целиком »
Просмотров: 618 | Комментариев: 0

Алгоритм хеширования Jenkins на Ассемблере

27.12.2024 | Категория: Образ мышления: Assembler | Автор: ManHunter
Семейство хеш-функций Jenkins ведет свою историю с 1997 года, когда этот алгоритм был впервые опубликован. Автором является Bob Jenkins, известный специалист в области создания генераторов псевдослучайных чисел и криптографии. Несмотря на кажущуюся простоту, хеш Jenkins обладает высокой скоростью работы и отличным лавинным эффектом. Даже на небольших объемах данных количество коллизий минимальное. Вот вариант этого алгоритма на Ассемблере.
  1. ;---------------------------------------------
  2. ; Функция вычисления хеша Jenkins
  3. ; Copyright (C) ManHunter / PCL
  4. ; https://www.manhunter.ru
  5. ;---------------------------------------------
  6. ; Параметры:
  7. ;       lpData - указатель на строку
  8. ;       dSize  - длина строки
  9. ; На выходе:
  10. ;       EAX = полученный хеш
  11. ;---------------------------------------------
  12. proc    Jenkins lpData:DWORD, dSize:DWORD
  13.         push    ebx ecx esi
  14.  
  15.         ; Инициализация
  16.         xor     ebx,ebx
  17.  
  18.         ; Длина строки
  19.         mov     ecx,[dSize]
  20.         or      ecx,ecx
  21.         je      .loc_ret
  22.  
  23.         mov     esi,[lpData]
  24. @@:
  25.         lodsb
  26.         movzx   eax,al
  27.  
  28.         ; hash += key[i];
  29.         add     ebx,eax
  30.  
  31.         ; hash += hash << 10;
  32.         mov     eax,ebx
  33.         shl     eax,10
  34.         add     ebx,eax
  35.  
  36.         ; hash ^= hash >> 6;
  37.         mov     eax,ebx
  38.         shr     eax,6
  39.         xor     ebx,eax
  40.  
  41.         ; i++
  42.         dec     ecx
  43.         jnz     @b
  44.  
  45. .loc_ret:
  46.         ; hash += hash << 3;
  47.         mov     eax,ebx
  48.         shl     eax,3
  49.         add     ebx,eax
  50.  
  51.         ; hash ^= hash >> 11;
  52.         mov     eax,ebx
  53.         shr     eax,11
  54.         xor     ebx,eax
  55.  
  56.         ; hash += hash << 15;
  57.         mov     eax,ebx
  58.         shl     eax,15
  59.         add     eax,ebx
  60.  
  61.         pop     esi ecx ebx
  62.         ret
  63. endp
Функции передаются два параметра: указатель на данные и размер этих данных, на выходе DWORD с полученным значением хеша.

Читать статью целиком »
Просмотров: 405 | Комментариев: 0

Работа с TypeLib на Ассемблере

16.12.2024 | Категория: Образ мышления: Assembler | Автор: ManHunter

Работа с TypeLib на Ассемблере

В предыдущей статье, посвященной программам для работы с TypeLib, я обещал рассказать о возможностях программного доступа к содержимому этих библиотек. Напомню, что в TypeLib или, если по-русски, в библиотеке типов содержится информация о COM-объектах, их свойствах и методах, константах, структурах и т.п. Тема большая и интересная, по крайней мере для меня.

Читать статью целиком »
Просмотров: 362 | Комментариев: 0

Работа с файлами AVIF на Ассемблере

11.12.2024 | Категория: Образ мышления: Assembler | Автор: ManHunter

Работа с файлами AVIF на Ассемблере

Графический формат AVIF, основанный на видеокодеке AV1, набирает популярность в интернете за счет эффективности сжатия, а также сохранения мелких деталей, меньшего количества артефактов и отсутствия растекания цвета вокруг резких границ объектов на изображении. AVIF неплохо поддерживается браузерами, а некоторые сайты, например, AliExpress, используют изображения в формате AVIF как основные. В связи с этим встает вопрос о поддержке файлов формата AVIF в приложениях. Это может быть просто просмотр изображений или конвертирование в другие форматы.

Читать статью целиком »
Просмотров: 547 | Комментариев: 2

Использование библиотеки PCRE для работы с регулярными выражениями

23.11.2024 | Категория: Образ мышления: Assembler | Автор: ManHunter

Использование библиотеки PCRE для работы с регулярными выражениями

В предыдущей статье я упомянул об альтернативных инструментах для работы с регулярными выражениями. Наиболее известное из них - кроссплатформенная библиотека PCRE (Perl Compatible Regular Expressions). Библиотека абсолютно бесплатная, разрабатывается аж с 1997 года и используется во множестве серьезных проектов. Сегодня я покажу примеры использования этой библиотеки в приложениях на Ассемблере под Windows.

Читать статью целиком »
Просмотров: 496 | Комментариев: 0

Наверх
Powered by PCL's Speckled Band Engine 0.2 RC3
© ManHunter / PCL, 2008-2025
При использовании материалов ссылка на сайт обязательна
Время генерации: 0.08 сек. / MySQL: 3 (0.0141 сек.) / Память: 4.5 Mb
Наверх