既知のテキスト キーを使用して .net アプリケーションでテキスト文字列を暗号化し、同じ既知のキーを使用して Ruby で復号化する必要がありますが、これを実現するのに問題があります。文字列のエンコードの問題に関係していると思います。.Net から Ruby RC4 への例は、とらえどころのないことが証明されています。
Ruby側で無効な復号化を受けています。暗号化/復号化は、.net 実装で正常に機能します。しかし、暗号化された値を Ruby 実装にコピーして同じキーを使用すると、元の値が得られません。
以下は私の .net RC4 実装です (これには最高レベルのセキュリティは必要ありませんが、いくつかは優れています) :)
ruby 側では ruby-rc4 を使用しています https://github.com/caiges/Ruby-RC4
public string keytext = "thisismykey";
public Form1()
{
InitializeComponent();
}
public void RC4(ref Byte[] bytes, Byte[] key)
{
Byte[] s = new Byte[256];
Byte[] k = new Byte[256];
Byte temp;
int i, j;
for (i = 0; i < 256; i++)
{
s[i] = (Byte)i;
k[i] = key[i % key.GetLength(0)];
}
j = 0;
for (i = 0; i < 256; i++)
{
j = (j + s[i] + k[i]) % 256;
temp = s[i];
s[i] = s[j];
s[j] = temp;
}
i = j = 0;
for (int x = 0; x < bytes.GetLength(0); x++)
{
i = (i + 1) % 256;
j = (j + s[i]) % 256;
temp = s[i];
s[i] = s[j];
s[j] = temp;
int t = (s[i] + s[j]) % 256;
bytes[x] ^= s[t];
}
}
static byte[] GetBytes(string str)
{
Byte[] bytes = new byte[str.Length * sizeof(char)];
System.Buffer.BlockCopy(str.ToCharArray(), 0, bytes, 0, bytes.Length);
return bytes;
}
static string GetString(byte[] bytes)
{
char[] chars = new char[bytes.Length / sizeof(char)];
System.Buffer.BlockCopy(bytes, 0, chars, 0, bytes.Length);
return new string(chars);
}
private void button1_Click(object sender, EventArgs e)
{
Byte[] content = Encoding.ASCII.GetBytes(textBox1.Text);
RC4(ref content, Encoding.ASCII.GetBytes(keytext));
textBox2.Text = Encoding.ASCII.GetString(content);
RC4(ref content, Encoding.ASCII.GetBytes(keytext));
label1.Text = Encoding.ASCII.GetString(content);
}