|
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 146
|
|
Сжатие длинного пароля или как запихнуть два байта в один, перейда от hexadecimal к полному алфавиту26.02.2018, 13:03. Показов 1790. Ответов 11
Метки нет (Все метки)
Надеюсь,что мой пост не будет выглядеть как бред, и что задаю свой вопрос в правильном разделе(тем более профильного раздела для темы не существует).
Задача - сократить некий визуальный код (hexadecimal), на 30-50%, при этом разрешается использовать символы выше F, то есть полный англ. алфавит, от A до Z. Практическое применение - имеется некий пароль, в виде hexadecimal, выглядит так: 3AC2 822C 4EF9 8FAD. Заказчик берет этот пароль, заводит его в волшебное окошко и получает доступ к какому-то-ресурсу. По сути, данный пароль есть закриптованный(CryptoAPI) буффер из 8 байт, в который напиханы флаги, разрешения и т.д., все корректно в пределах 8 байт. Но ... у заказчика проблема, из-за специфики фирмы очень часто эти пароли передаются по телефону в устной форме, и местные работники начали упрашивать нас сократить по максимуму длину кода. Так, чтобы например, вместо четырех символов "3AC2" можно было ввести три символа "RXZ" или два символа "XZ". Русский алфавит использовать не могу, только английский. Разумеется, любая потеря данных исключается. То есть, вместо набора 0-9, A-F я могу теперь пользоваться набором 0-9, A-Z. Это безусловно расширяет возможности для сжатия, вопрос, на сколько, а главное, где можно найти примеры? Буду рад любой подсказке
0
|
|
| 26.02.2018, 13:03 | |
|
Ответы с готовыми решениями:
11
Один на один, или как привязать два пересекающихся объекта друг к другу? Как заставить ereg_replace менять два стоящих подряд обратных слэша или один прямой на один обратный?
|
|
5120 / 4573 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
|
|
| 26.02.2018, 14:03 | |
|
vkiper, идея навскидку: считаем поток бит (рассматриваем не строку hex, а сами байты) непрерывным.
Группируем по 5 бит (порядок - на усмотрение), последнюю группу дополняем нужным количеством нулей. В итоге получаем получаем 32 разных значений. Или все английские буквы ![]() Добавлено через 6 минут 3AC2 822C 4EF9 8FAD (16 символов) дает 13 символов ![]() Добавлено через 1 минуту экономия 18.75 % Не 50, конечно, и даже, не 30...Добавлено через 42 секунды Я еще подумаю на досуге, может еще что-то "стукнет" ... ![]() Добавлено через 11 минут vkiper, еще идея ![]() рассматриваем наш hex-код, как большое число. Порядок байт опять же на усмотрение. И преобразуем его в 42-ричную систему счисления, другими словами, делим на 42 и накапливаем остатки. В итоге получим 42 разных значений (т.е. полностью охватим 0-9, A-Z) Экономия будет больше ![]() Для того же числа получим 12 символов (25%)...
1
|
|
|
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 146
|
|
| 26.02.2018, 15:16 [ТС] | |
|
понял, спасибо, попробую потестить
0
|
|
|
5120 / 4573 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
|
|
| 27.02.2018, 11:44 | |
|
vkiper, если разрешить маленькие английские буквы, то деля на 74, получим еще меньше код.
Но, так понял, маленькие не устраивают, дабы не вносить разночтение
0
|
|
|
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 146
|
||||||
| 27.02.2018, 12:44 [ТС] | ||||||
|
Маленькие буквы не разрешают, даже с такими буквами будут траблы, например, мы в состоянии отличить ноль от буквы О, а средний оператор в фирме не всегда это сделает, скажем, у нас есть: F3NO и F3N0, куча простора для разночтения. Можно с фонтами поиграться и т.д. ... вообще не уверен, что данная идея будет живучей и пройдет все разрешения в конце. Тем не менее, я приготовил работающую концепуху, за разрядность взяв 36, вот код:
Почему я взял за базу именно 36, думаю, понятно - мы имеем 10 цифр и 26 букв алфавита. Главное - это спасибо за идею с разрядностью и остатком по модулю, я бы сам долго к этому полз... мозги стали зашоренные, а с битами-байтами ненавижу возиться.
0
|
||||||
|
5120 / 4573 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
|
|
| 27.02.2018, 12:57 | |
|
vkiper, собственно, именно это и имел в виду. Чего-то подумал, что английских букв 32 (а не 26).
Идейка: можно убрать разночтение нуля и буквы 'O'. Просто убрать 'O' (или нуль)
0
|
|
|
571 / 353 / 133
Регистрация: 15.09.2017
Сообщений: 1,239
|
|
| 27.02.2018, 13:00 | |
|
Разбей на 4 по 2 байта и переведи в юникод
![]()
0
|
|
|
5120 / 4573 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
|
||
| 27.02.2018, 13:12 | ||
|
Покажите на примере. Лично я "не догоняю". Добавлено через 9 минут Если это сарказм, то он тут неуместен... Шутки шутить давайте в другом месте...
0
|
||
|
571 / 353 / 133
Регистрация: 15.09.2017
Сообщений: 1,239
|
|||
| 27.02.2018, 13:15 | |||
![]() Добавлено через 51 секунду
0
|
|||
|
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
|
||
| 27.02.2018, 15:07 | ||
|
Разбиваем пароль на пары из двух hexadecimal. Каждой возможной паре ставим в соответствие одно из 256 заранее заготовленных слов. Диктуем пароль как "водка (3A) блин (C2) автомобиль (82) береза (2C)". И жалобы на то что кто-то, что-то там по телефону недослышал резко сокращаются. Если все равно слишком длинно - ну, словарь большой, можно и 65536 слов для четырех hexadecimal разом сделать. А на стороне заказчика, если уж сильно надо, какой ни будь наколеночный скрипт собирает эти блины в березах обратно в пароль.
0
|
||
|
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 146
|
|
| 27.02.2018, 15:18 [ТС] | |
|
Идея неплохая, но для нашего начальства(а для заказчика тем более) будет выглядеть слишком заумной и сложной в реализации. Хотя выглядит красиво, должен признать.
0
|
|
|
5120 / 4573 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
|
|
| 27.02.2018, 15:29 | |
|
А что? Написать программку, которая автоматом подменит hex на слова и выдаст их, как пароль
![]() На приеме, проблем и мороки немного больше. Надо слова как-то записать и ввести. Вполне возможны орфографические ошибки, что приведет к непониманию... PS Почему-то представился диалог времен ВОВ: "Сосна, сосна, я береза"
0
|
|
| 27.02.2018, 15:29 | |
|
Помогаю со студенческими работами здесь
12
Сжатие изображения TrueColor (несколько точек) в 4 байта Как запихнуть в один элемент массива значения нескольких полей TextBox? Один файл - запихнуть всё в один ексешник Как изменить два старших байта Как сложить два байта регистра AX Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|