1

で文字列のハッシュGNAT.SHA1を作成するために使用しています。私のコードベースは小さいので、コンパイラによって提供されていないライブラリをプロジェクトにインポートしないようにしたいので、を使用しています。私の知る限り、ハッシュを取得するための「パブリック」メソッドは、関数を介した文字列形式のみです。代わりに、このタイプのメンバーである160ビットブロックを取得したいと思います。残念ながら、レコードは非公開です。私がそれを得ることができる方法はありますか?または、Ada標準ライブラリによって提供される代替方法ですか?SHA1AdaGNAT.SHA1DigestHContextContextGNAT

4

1 に答える 1

4

160ビットブロックを取得する直接的な方法はわかりませんが、もちろん、16進文字列から計算することはできます。

これが私が一緒に投げた例です。"16#"(確かに、16進部分文字列にとを追加して32ビット整数を抽出する"#"ことは、最も洗練された解決策ではない場合があります。

with GNAT.SHA1;
with Interfaces;
with Ada.Text_IO; use Ada.Text_IO;
with Ada.Integer_Text_IO; use Ada.Integer_Text_IO;
procedure SHA1_Demo is
    C: GNAT.SHA1.Context;
    package U32_IO is new Ada.Text_IO.Modular_IO(Interfaces.Unsigned_32);
    use U32_IO;
begin
    GNAT.SHA1.Update(C, "hello");
    declare
        SHA1: constant String := GNAT.SHA1.Digest(C);
        H: array(0..4) of Interfaces.Unsigned_32;
    begin
        Put_Line("SHA1(""hello"") = " & GNAT.SHA1.Digest(C));
        for I in Integer range 0 .. 4 loop
            H(I) := Interfaces.Unsigned_32'Value
                        ("16#" & SHA1(I*8+1 .. I*8+8) & "#");
            Put("H(");
            Put(I, Width => 0);
            Put(") = ");
            Put(H(I), Base => 16);
            New_Line;
        end loop;
    end;
end SHA1_Demo;

出力は次のとおりです。

SHA1("hello") = aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d
H(0) = 16#AAF4C61D#
H(1) = 16#DCC5E8A2#
H(2) = 16#DABEDE0F#
H(3) = 16#3B482CD9#
H(4) = 16#AEA9434D#
于 2012-01-14T12:12:02.513 に答える