Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
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
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.02.2018, 13:03
Ответы с готовыми решениями:

Один на один, или как привязать два пересекающихся объекта друг к другу?
Здравствуйте! Сразу к делу: чтобы было понятно, представьте себе дорогу(трассу, с видом сверху) по которой движутся автомобили без...

Как заставить ereg_replace менять два стоящих подряд обратных слэша или один прямой на один обратный?
Как заставить ereg_replace менять два стоящих подряд обратных слэша или один прямой на один обратный?

Как вытащить из строки один или два совпадения по условию?
Добрый день, Есть 2 строки: 1) 5818M8001966ABHF- 2) 4137M33X24001- Интересует такой вопрос: Как в 1) узнать, что перед -...

11
Эксперт CЭксперт С++
 Аватар для liv
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
Эксперт CЭксперт С++
 Аватар для liv
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, вот код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
char _g_arrNums[36] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' };
 
int IndexFromBase36(char ch)
{
    for (int i = 0; i < 36; i++)
    {
        if (ch == _g_arrNums[i])
            return i;
    }
    return -1; //illegal case
}
bool Hex2Base36()
{
#define BASE_36  36
 
    char szHexString[] = "0x2D02BB12C7AE828F";
 
    char szBase36Buff[64] = { 0 };
 
    // 1 - get number from hex string
    LONGLONG longNumber = strtoll(szHexString, NULL, 16);
 
    // 2 - convert to base36 string
    {
        LONGLONG rest = longNumber;
        int index = 0;
        do
        {
            int mod = rest % BASE_36; // get remainder
            szBase36Buff[index] = _g_arrNums[mod]; //add to base36 buffer
            rest = (LONGLONG)rest / BASE_36; //update number
            index++;
        } while (rest > 0);
    }
 
    //_strrev(szBase36Buff); //reverse, if need, for correct visual view
 
    // 3 - convert from base36 string to hexadecimal
    {
        int len = strlen(szBase36Buff);
        LONGLONG result = 0;
        for (int nn = 0; nn < len; nn++)
        {
            int mod = IndexFromBase36(szBase36Buff[nn]);
            LONGLONG multiplier = pow(BASE_36, nn);
            LONGLONG tmp = (nn == 0) ? mod : (mod * multiplier);
            result += tmp;
        }
 
        if (result != longNumber)
        {
            //we've failed........
            return false;
        }
    }
 
    return true;
}
В случае с числом 2D02BB12C7AE828F на выходе имеем 7ULOA1PAF3NO, экономия 24%. Не густо, но мне кажется, выше мы уже и не прыгнем.
Почему я взял за базу именно 36, думаю, понятно - мы имеем 10 цифр и 26 букв алфавита.

Главное - это спасибо за идею с разрядностью и остатком по модулю, я бы сам долго к этому полз... мозги стали зашоренные, а с битами-байтами ненавижу возиться.
0
Эксперт CЭксперт С++
 Аватар для liv
5120 / 4573 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
27.02.2018, 12:57
vkiper, собственно, именно это и имел в виду. Чего-то подумал, что английских букв 32 (а не 26).
Идейка: можно убрать разночтение нуля и буквы 'O'. Просто убрать 'O' (или нуль)
0
 Аватар для Avaddon74
571 / 353 / 133
Регистрация: 15.09.2017
Сообщений: 1,239
27.02.2018, 13:00
Разбей на 4 по 2 байта и переведи в юникод
0
Эксперт CЭксперт С++
 Аватар для liv
5120 / 4573 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
27.02.2018, 13:12
Цитата Сообщение от Avaddon74 Посмотреть сообщение
Разбей на 2 по 2 байта и переведи в юникод
и в чем экономия?
Покажите на примере. Лично я "не догоняю".

Добавлено через 9 минут
Если это сарказм, то он тут неуместен... Шутки шутить давайте в другом месте...
0
 Аватар для Avaddon74
571 / 353 / 133
Регистрация: 15.09.2017
Сообщений: 1,239
27.02.2018, 13:15
Цитата Сообщение от _liv_ Посмотреть сообщение
и в чем экономия?
из-за специфики фирмы очень часто эти пароли передаются по телефону в устной форме, и местные работники начали упрашивать нас сократить по максимуму длину кода
Вместо 16 символов диктовать 4 иероглифа из юникода. А вообще не парься, это был сарказм

Добавлено через 51 секунду

Не по теме:

Цитата Сообщение от _liv_ Посмотреть сообщение
Шутки шутить давайте в другом месте..
Какие мы серьезные!

0
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
27.02.2018, 15:07
Цитата Сообщение от vkiper Посмотреть сообщение
Но ... у заказчика проблема, из-за специфики фирмы очень часто эти пароли передаются по телефону в устной форме, и местные работники начали упрашивать нас сократить по максимуму длину кода.
А может выдать заказчику не то что он просит, а то что ему надо?
Разбиваем пароль на пары из двух hexadecimal. Каждой возможной паре ставим в соответствие одно из 256 заранее заготовленных слов. Диктуем пароль как "водка (3A) блин (C2) автомобиль (82) береза (2C)". И жалобы на то что кто-то, что-то там по телефону недослышал резко сокращаются. Если все равно слишком длинно - ну, словарь большой, можно и 65536 слов для четырех hexadecimal разом сделать. А на стороне заказчика, если уж сильно надо, какой ни будь наколеночный скрипт собирает эти блины в березах обратно в пароль.
0
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 146
27.02.2018, 15:18  [ТС]
Идея неплохая, но для нашего начальства(а для заказчика тем более) будет выглядеть слишком заумной и сложной в реализации. Хотя выглядит красиво, должен признать.
0
Эксперт CЭксперт С++
 Аватар для liv
5120 / 4573 / 855
Регистрация: 07.10.2015
Сообщений: 9,462
27.02.2018, 15:29
А что? Написать программку, которая автоматом подменит hex на слова и выдаст их, как пароль
На приеме, проблем и мороки немного больше. Надо слова как-то записать и ввести.
Вполне возможны орфографические ошибки, что приведет к непониманию...

PS Почему-то представился диалог времен ВОВ: "Сосна, сосна, я береза"
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.02.2018, 15:29
Помогаю со студенческими работами здесь

Сжатие изображения TrueColor (несколько точек) в 4 байта
Посоветуйте алгоритм для упаковки информации о как можно большем количестве точек в 32 бита. Можно с потерей качества. Но тогда эта потеря...

Как запихнуть в один элемент массива значения нескольких полей TextBox?
подскажите, как запихнуть в ОДИН элемент массива значения нескольких полей TextBox?

Один файл - запихнуть всё в один ексешник
Здравствуйте,скажите.Вот есть программа,написанная в Билдере 06.В программе используются картинки и звуковые файлы.Есть ли возможность...

Как изменить два старших байта
Помогите исправить ошибку. Задание: long int a=11223344; int b=5566; Получить long int a=55116633; int b=2244; long int...

Как сложить два байта регистра AX
Ребята подскажите, как сложить два байта регистра AX? Если я правильно понимаю, то после сложения должна появиться строчка: ADD AH, AL . Я...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
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 . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru