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

Есть у меня вот такая штука в ASN-1 SignerInfoAuthenticatedAttributes ::= CHOICE

{
aaSet [0] IMPLICIT SET OF AttributePKCS-7 {{Authenticated}},
aaSequence [2] EXPLICIT SEQUENCE OF AttributePKCS-7 {{Authenticated}}
-- Explicit because easier to compute digest on sequence of attributes and then reuse
-- encoded sequence in aaSequence.
}

я ее откуда-то успешно вычитываю, получаю {aaSet, ....} = AASet
дальше мне нужно ее упаковать обратно, я делаю public_key:der_encode('SignerInfoAuthenticatedAttributes', AASet), мне возвращается <<160, ...>>. от этого выходит неверный дайджест.

код на питоне читает те же исходные данные, но с кодированием этих данных предварительно делает какое-то шаманство, и в нем получается <<49, ...>>, дальше байты совпадают, дайджест сходится.

насколько я понял, 160 - это [0] implicit, и да, rfc явно говорит, что он не является частью данных. вопрос, наверное в том, можно ли как-то как-то получить нужное представление, не трогая руками бинарное представление?

3 ответов

28 просмотров

где в rfc это сказано?

Alex-Bubnov Автор вопроса
Lev Walkin
где в rfc это сказано?

https://datatracker.ietf.org/doc/html/rfc2315#section-9.3 (For clarity: The IMPLICIT [0] tag in the authenticatedAttributes field is not part of the Attributes value. The Attributes value's tag is SET OF, and the DER encoding of the SET OF tag, rather than of the IMPLICIT [0] tag, is to be digested along with the length and contents octets of the Attributes value.) Ужас, да?

Alex Bubnov
https://datatracker.ietf.org/doc/html/rfc2315#sect...

нет, я читаю это по-другому. Можем созвониться, чтобы другим не мешать.

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
1
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Карта сайта