0

Salted Challenge Response Authentication Mechanism ( RFC 5802 ) を実装しようとしていますが、少し問題が発生しています。

Hi(str, salt, i):

U1   := HMAC(str, salt + INT(1))
U2   := HMAC(str, U1)
...
Ui-1 := HMAC(str, Ui-2)
Ui   := HMAC(str, Ui-1)

Hi := U1 XOR U2 XOR ... XOR Ui

where "i" is the iteration count, "+" is the string concatenation
operator, and INT(g) is a 4-octet encoding of the integer g, most
significant octet first.

INT(1) を追加する方法がわかりません。私はソルト用のバイト配列を持っています。1 をビットシフトして配列の末尾に追加するだけでよいのでしょうか?

4

1 に答える 1

1

配列には何も追加できません。配列は固定サイズであるため、結果用に新しい配列を作成する必要があります。クラスを使用してBitConverter、整数のバイナリ表現を取得します。

// create new array
byte[] key = new byte[salt.Length + 4];
// copy salt
Array.Copy(salt, key, salt.Length);
// create array from integer
byte[] g = BitConverter.GetBytes(1);
if (BitConverter.IsLittleEndian) {
  Array.Reverse(g);
}
// copy integer array
Array.Copy(g, 0, key, salt.Length, 4);
于 2011-02-15T20:59:20.593 に答える