C#中的RC4 128位加密

我需要执行128位RC4加密,我使用的是.NET和C#。 是否有内置函数来执行此操作。

如果没有,我发现这个function可以做到:

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,但我真的不知道它的区别。

根据http://en.wikipedia.org/wiki/Rc4 RC4算法可以有keylength,其范围可以是1≤keylength≤256
以下是您可以确定密钥大小的示例: http : //tofuculture.com/Blog/post/RC4-Encryption-in-C.aspx
下载源代码并查看RC4.cs.

密钥设置是该算法的第一个也是最困难的阶段。 在N位密钥设置(N是密钥长度)期间,加密密钥用于使用两个arrays,状态和密钥以及N个混合操作生成加密变量。 这些混合操作包括交换字节,模运算和其他公式。

在附加的项目中,您可以在RC4Engine类的EncryptionKey set属性中看到我是如何做到的。

这是一篇有趣的文章 – http://www.codeproject.com/Articles/5068/RC4-Encryption-Algorithm-C-Version

我可以告诉你,.Net Framework中没有RC4算法。 有一个RC2加密……但没有RC4。