ஜான் தி ரிப்பர் 1.9.0-ஜம்போ-1 FPGA ஆதரவுடன் வெளியிடப்பட்டது

வெளியிடப்பட்டது новая версия старейшей поддерживаемой программы для подбора паролей John the Ripper 1.9.0-jumbo-1 (проект развивается с 1996 года). C выхода прошлой версии 1.8.0-jumbo-1 прошло 4.5 года, за которые было внесено более 6000 изменений (git commits) от более 80 разработчиков. Благодаря தொடர்ச்சியான ஒருங்கிணைப்பு, включающей предварительную проверку каждого изменения (pull request) на многих платформах, в течение этого срока разработчики рекомендовали использовать GitHub இலிருந்து தற்போதைய பதிப்பு, состояние которой поддерживалось стабильным несмотря на вносимые изменения. Основной код проекта வழங்கியது под лицензией GPLv2+, а код некоторых компонентов под лицензией BSD.

Особенностью новой версии является появление поддержки FPGA (в дополнение к CPU, GPU и Xeon Phi). Для плат ZTEX 1.15y, включающих по 4 чипа FPGA и исходно использовавшихся в основном для майнинга Bitcoin, теперь реализованы 7 типов хешей паролей: bcrypt, классический descrypt (включая bigcrypt), sha512crypt, sha256crypt, md5crypt (включая Apache apr1 и AIX smd5), Drupal7 и phpass (используется, в частности, в WordPress). Некоторые из них реализованы на FPGA впервые.

Для bcrypt, достигнутая производительность в ~119k c/s при 2^5 итераций («$2b$05») с потребляемой мощностью около ~27 ватт существенно превосходит результаты для новейших GPU в расчете на плату, на цену оборудования и на ватт. Также поддерживаются கொத்துகள் из плат этого типа, что проверено вплоть до 16 плат (64 чипа FPGA), контролируемых с одного Raspberry Pi 2. Поддерживается обычная функциональность John the Ripper, включая все режимы подбора паролей и одновременную загрузку большого количества хешей.

Для ускорения работы реализовано применение маски (режим «—mask», в том числе в комбинации с другими режимами) и сравнение вычисленных хешей с загруженными на стороне FPGA. С точки зрения реализации, во многих из дизайнов (например, для sha512crypt மற்றும் Drupal7கிரிப்டோகிராஃபிக் கோர்களுடன் தொடர்பு கொள்ளும் பல-திரிக்கப்பட்ட செயலி கோர்கள் (மென்மையான CPU கோர்கள்) கொண்ட தொகுதிகள் பயன்படுத்தப்படுகின்றன. மற்ற ஜம்போ டெவலப்பர்களுடன் ஒருங்கிணைந்து டெனிஸ் புரிகின் இந்த செயல்பாட்டின் வளர்ச்சியை வழிநடத்தினார்.

Другие важные изменения:

  • Поддержка большого количества дополнительных типов хешей, шифров и т.п., включая как классические хеши паролей (например, от новых версий QNX), так и кошельки криптовалют, шифрованные архивы и шифрованные файловые системы (например, Bitlocker и FreeBSD geli), а также поддержку новых разновидностей форматов, поддерживаемых ранее (например, добавлена поддержка bcrypt-pbkdf для OpenBSD softraid) и многое другое. В общей сложности, добавлено 80 форматов на CPU и 47 на OpenCL. Общее количество форматов теперь 407 на CPU (или 262 не включая «dynamic» форматы, настраиваемые из файлов конфигурации) и 88 на OpenCL.
  • OpenCL க்கு ஆதரவாக CUDA மொழியை ஆதரிக்க மறுப்பது, இது NVIDIA GPUகளின் முழுப் பயன்பாட்டிற்கு எந்த வகையிலும் இடையூறு செய்யாது (மேலும், GPU க்காக இரண்டு செயலாக்கங்களுக்குப் பதிலாக, GPU க்காக ஒவ்வொரு வடிவத்திலும் ஒரு செயலாக்கத்தை மேம்படுத்துதல் மற்றும் மேம்படுத்துதல் ஆகியவற்றில் கவனம் செலுத்துவதற்கும் உதவுகிறது).
  • புதிய SIMD அறிவுறுத்தல் தொகுப்புகளுக்கான ஆதரவு - AVX2, AVX-512 (இரண்டாம் தலைமுறை Xeon Phi உட்பட) மற்றும் MIC (முதல் தலைமுறைக்கானது) - அத்துடன் SIMD இன் பயன்பாடு உட்பட பல வடிவங்களின் செயலாக்கங்களில் உலகளாவிய மற்றும் முழுமையான பயன்பாடு. x86(-64) இல் AVX மற்றும் XOP வரையிலான முன்னரே ஆதரிக்கப்பட்ட வழிமுறைகள் மற்றும்
    NEON, ASIMD и AltiVec на ARM, Aarch64 и POWER, соответственно.

  • CPU மற்றும் OpenCL ஆகியவற்றுக்கான பல மேம்படுத்தல்கள், ஒரே நேரத்தில் அதிக எண்ணிக்கையிலான ஹாஷ்களுடன் மிகவும் திறமையாக வேலை செய்ய (உதாரணமாக, GPU இல் 320 மில்லியன் SHA-1 ஹாஷ்களை ஏற்றுவது சோதிக்கப்பட்டது), மற்றும் ஹாஷ் கணக்கீடுகளின் வேகத்தை அதிகரிக்க. இந்த மேம்படுத்தல்களில் சில உலகளாவியவை, சில வடிவங்களின் வெவ்வேறு துணைக்குழுக்களை உள்ளடக்கியது, மேலும் பல தனிப்பட்ட வடிவங்களுக்கு குறிப்பிட்டவை.
  • (Авто-)настройка оптимальной буферизации проверяемых паролей на CPU («—tune=auto —verbosity=5») и оптимальных размерностей задания на OpenCL (включена по умолчанию), в том числе с учетом медленного выхода на полную рабочую частоту GPU серии NVIDIA GTX 10xx и новее. Использование реально загруженных хешей и реальной длины проверяемых паролей (когда она известна заранее) для такой авто-настройки.
  • Добавление компилятора «динамических выражений», указываемых прямо на командной строке и реализующих новые гибридные типы хешей, например «—format=dynamic=’sha1(md5($p).$s)'», вычисляемые на CPU с использованием SIMD. В качестве компонентов таких выражений поддерживаются десятки быстрых хешей (от распространенных вроде MD5 до умеренно экзотических вроде Whirlpool), объединение подстрок, кодирование и декодирование, преобразование регистра символов, ссылки на пароль, соль, имя пользователя и строковые константы.
  • முந்தைய ஹாஷ்கேட்-குறிப்பிட்ட விதிகளுக்கான ஆதரவு (வேர்ட்லிஸ்ட் விதி கட்டளைகள்), 1 இலிருந்து OpenCL சாதன எண்ணுக்கு மாறுதல், செயல்திறன் சோதனைகளுக்கு அதே கடவுச்சொல் நீளங்களின் இயல்புநிலை பயன்பாடு (பொதுவாக நீளம் 7) உட்பட, hashcat இலிருந்து தேவையற்ற வேறுபாடுகளை நீக்குதல்.
  • சரிபார்க்கக்கூடிய கடவுச்சொற்களை உருவாக்குவதற்கான புதிய முறைகள் (கிராக்கிங் பயன்முறைகள்), ஹாஷ்கேட்டிலிருந்து PRINCE (மொத்த நீளத்தின் வரிசையை பல வார்த்தைகளை இணைத்து "சொற்றொடர்களை" உருவாக்குகிறது), துணைக்குழுக்கள் (இந்த எழுத்துக்கள் வந்தாலும் கூட, கடவுச்சொற்களை போதுமான எண்ணிக்கையில் வெவ்வேறு எழுத்துக்கள் கொண்டு வரும். சாத்தியமானவற்றின் பெரிய தொகுப்பிலிருந்து) மற்றும் கலப்பின வெளிப்புற (வெளிப்புற முறைகள், C-போன்ற மொழியில் உள்ளமைவு கோப்புகளில் விவரிக்கப்பட்டுள்ளது, மற்றொரு பயன்முறையிலிருந்து பெறப்பட்ட ஒவ்வொரு அடிப்படை "வார்த்தை" அடிப்படையில் பல சரிபார்க்கக்கூடிய கடவுச்சொற்களை உருவாக்க அனுமதிக்கிறது). மேலும், பல புதிய முன் வரையறுக்கப்பட்ட வெளிப்புற முறைகள்.
  • ஒரே நேரத்தில் பல முறைகளைப் பயன்படுத்துவதற்கான கூடுதல் அம்சங்கள் (ஒன்று மேல் ஒன்று - அடுக்கி வைத்தல்), அத்துடன் விதிகளின் தொகுப்புகளைப் பயன்படுத்துதல் (வார்த்தைப்பட்டியல் விதிகள் குவியலிடுதல்).
  • முகமூடி முறைகளில் மேம்பாடுகள் (குறிப்பிட்ட நீளத்தில் முகமூடியை படிப்படியாக நீட்டுதல், OpenCL சாதனம் அல்லது FPGA பலகையின் பக்கத்தில் முகமூடியைப் பயன்படுத்துதல்) மற்றும் ஒற்றை கிராக் (இணையாக அதிக எண்ணிக்கையிலான ஹாஷ்களைக் கணக்கிடும் சாதனங்களில் நியாயமான நடத்தை , இதற்கு முன்பு இந்த பயன்முறையில் போதுமான சரிபார்க்கக்கூடிய கடவுச்சொற்கள் இல்லை, மேலும் நினைவக நுகர்வு மீதான கட்டுப்பாடுகள்).
  • பல்வேறு துணை அமைப்புகளில் யூனிகோட் மற்றும் பிற குறியாக்கங்களை ஆதரிக்க பல மேம்பாடுகள்.
  • *2john நிரல்களில் பல மேம்பாடுகள் (பல்வேறு வடிவங்களின் கோப்புகளை மாற்றும்
    ஜானுடன் பயன்படுத்தவும்), குறிப்பாக wpapcap2john (வைஃபை டிராஃபிக்கைக் கையாளுகிறது).

  • பல புதிய கட்டளை வரி விருப்பங்கள் உள்ளன, john.conf இல் அமைப்புகள், ஸ்கிரிப்ட் விருப்பங்களை உள்ளமைத்தல் மற்றும் தொடர்புடைய புதிய அம்சங்கள், இவை அனைத்தும் இங்கு குறிப்பிடப்படவில்லை.
  • AddressSanitizer (முந்தைய) மற்றும் UndefinedBehaviorSanitizer (சேர்க்கப்பட்டது) உடன் டிபக் பில்ட்களுக்கான உள்ளமைக்கப்பட்ட ஆதரவின் குறியீட்டின் தரத்தை மேம்படுத்துதல், தொடர்ச்சியான ஒருங்கிணைப்பைப் பயன்படுத்தி (GSoC 2015 இன் ஒரு பகுதியாக) உள்ளமைக்கப்பட்ட ஃபார்மேட் ஃபஸரைச் சேர்த்தல் சேர்க்கைகள் மற்றும் அனைத்து வடிவங்களுக்கும் சரியான ஆதரவுக்காக அவற்றைச் சோதித்தல்).

ஆதாரம்: opennet.ru

கருத்தைச் சேர்