17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 100
1

Сжатие длинного пароля или как запихнуть два байта в один, перейда от hexadecimal к полному алфавиту

26.02.2018, 13:03. Показов 1433. Ответов 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
26.02.2018, 13:03
Ответы с готовыми решениями:

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

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

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

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

11
Модератор
Эксперт CЭксперт С++
5104 / 4533 / 854
Регистрация: 07.10.2015
Сообщений: 9,463
26.02.2018, 14:03 2
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
Сообщений: 100
26.02.2018, 15:16  [ТС] 3
понял, спасибо, попробую потестить
0
Модератор
Эксперт CЭксперт С++
5104 / 4533 / 854
Регистрация: 07.10.2015
Сообщений: 9,463
27.02.2018, 11:44 4
vkiper, если разрешить маленькие английские буквы, то деля на 74, получим еще меньше код.
Но, так понял, маленькие не устраивают, дабы не вносить разночтение
0
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 100
27.02.2018, 12:44  [ТС] 5
Маленькие буквы не разрешают, даже с такими буквами будут траблы, например, мы в состоянии отличить ноль от буквы О, а средний оператор в фирме не всегда это сделает, скажем, у нас есть: 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Эксперт С++
5104 / 4533 / 854
Регистрация: 07.10.2015
Сообщений: 9,463
27.02.2018, 12:57 6
vkiper, собственно, именно это и имел в виду. Чего-то подумал, что английских букв 32 (а не 26).
Идейка: можно убрать разночтение нуля и буквы 'O'. Просто убрать 'O' (или нуль)
0
570 / 352 / 133
Регистрация: 15.09.2017
Сообщений: 1,239
27.02.2018, 13:00 7
Разбей на 4 по 2 байта и переведи в юникод
0
Модератор
Эксперт CЭксперт С++
5104 / 4533 / 854
Регистрация: 07.10.2015
Сообщений: 9,463
27.02.2018, 13:12 8
Цитата Сообщение от Avaddon74 Посмотреть сообщение
Разбей на 2 по 2 байта и переведи в юникод
и в чем экономия?
Покажите на примере. Лично я "не догоняю".

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

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

Не по теме:

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

0
2753 / 1908 / 568
Регистрация: 05.06.2014
Сообщений: 5,559
27.02.2018, 15:07 10
Цитата Сообщение от vkiper Посмотреть сообщение
Но ... у заказчика проблема, из-за специфики фирмы очень часто эти пароли передаются по телефону в устной форме, и местные работники начали упрашивать нас сократить по максимуму длину кода.
А может выдать заказчику не то что он просит, а то что ему надо?
Разбиваем пароль на пары из двух hexadecimal. Каждой возможной паре ставим в соответствие одно из 256 заранее заготовленных слов. Диктуем пароль как "водка (3A) блин (C2) автомобиль (82) береза (2C)". И жалобы на то что кто-то, что-то там по телефону недослышал резко сокращаются. Если все равно слишком длинно - ну, словарь большой, можно и 65536 слов для четырех hexadecimal разом сделать. А на стороне заказчика, если уж сильно надо, какой ни будь наколеночный скрипт собирает эти блины в березах обратно в пароль.
0
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 100
27.02.2018, 15:18  [ТС] 11
Идея неплохая, но для нашего начальства(а для заказчика тем более) будет выглядеть слишком заумной и сложной в реализации. Хотя выглядит красиво, должен признать.
0
Модератор
Эксперт CЭксперт С++
5104 / 4533 / 854
Регистрация: 07.10.2015
Сообщений: 9,463
27.02.2018, 15:29 12
А что? Написать программку, которая автоматом подменит hex на слова и выдаст их, как пароль
На приеме, проблем и мороки немного больше. Надо слова как-то записать и ввести.
Вполне возможны орфографические ошибки, что приведет к непониманию...

PS Почему-то представился диалог времен ВОВ: "Сосна, сосна, я береза"
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
27.02.2018, 15:29
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru