169 похожих чатов

Ребят а кто шарит. Многие типы хеш-функций создают хэш разной

длины. Почему?

8 ответов

224 просмотра

Размер хэша в битах всегда одинаковый, меняется только кол-во символов. Закинь два хэша в калькулятор, скорее всего их вес будет равен 256 битам (в зависимости от алгоритма шифрования). Я думаю что хэш в шестнадцатеричной сч. может сокращать строку на несколько символов из-за ненадобности, т.к. побитово хэш всё равно будет равен 256 битам. Т.е. число X = 256 битам и 32 символам, а число Y = 256 битам и 33 символам, но числа эти разные, т.к. при кодировке 32 символов были использованы более высокие разряды. На пример число 100000 (в 10 сч.) = 186A0 (в 16 сч). Но если мы добавим ещё один нолик: 1000000 (в 10 сч), то это будет F4240 (в 16 сч). Обрати внимание, что мы из ста тысяч сделали один миллион, но при конвертации в шестнадцатиричную сч. мы получили число также состоящие из 5-и символов (как и при предыдущей конвертации), но использовались более высокие разряды чисел. Таким образом, если мы что-то хэшируем, то сначала мы получим побитовое представление информации (которое можно сравнить с нашим десятичным числом), а потом с помощью алгоритма получаем шестнадцатиричный хэш. Так вот, это побитовое число может быть переведено в 32 или 33 шестнадцатиричных символа, как в моём примере. Я не уверен, что это происходит именно из-за этого, но опираясь на свою эрудицию в данной теме могу предположить, что это логичное объяснение.

Олександр Курсеітов [NO MERCY]
Спасибо, добрий-умный человек!!!_)

Ты погоди радоваться, я могу ошибаться Но вроде всё логично

Danila
Чё-то на сишном, ничего не понял

Не, на общекриптографическом

Похожие вопросы

Обсуждают сегодня

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Всем привет, у меня есть сервер принимающий входящие HTTP подключения, как проверить, что подключение было через прокси или нет, есть какие то поля в заголовках по которым мо...
DS
8
Карта сайта