我需要执行128位RC4加密,我正在使用.NET和C#。是否有内置函数来执行此操作。
如果没有,我发现这个功能可以做到:
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];
}
}
但我不知道它是不是128位,它看起来是256,但我真的不知道它的区别。
答案 0 :(得分:3)
根据http://en.wikipedia.org/wiki/Rc4 RC4算法可以得到密钥长度,其范围可以是1≤keylength≤256
以下是您可以确定密钥大小的示例:http://tofuculture.com/Blog/post/RC4-Encryption-in-C.aspx
下载源代码并查看RC4.cs。
答案 1 :(得分:2)
密钥设置是此算法的第一个也是最困难的阶段。在N位密钥设置(N是密钥长度)期间,加密密钥用于使用两个阵列,状态和密钥以及N个混合操作生成加密变量。这些混合操作包括交换字节,模运算和其他公式。
在附加项目中,您可以在RC4Engine类的EncryptionKey set属性中看到我是如何做到的。
这是一篇关于这个主题的有趣文章 - http://www.codeproject.com/Articles/5068/RC4-Encryption-Algorithm-C-Version
答案 2 :(得分:0)
我可以告诉你,.Net Framework中没有RC4算法。有一个RC2加密......但没有RC4。