我复制并使用了此页面示例中的C#代码C# equivalent to this ColdFusion Decrypt function,但它对我不起作用。我不确定该页面上的coldfusion解密样本是否与我的相同。无论如何,我的coldfusion代码是这样的:
加密:
<cfset strBase64Value = ToBase64(encrypt(strValue,"mykey")) />
解密:
<cfset strDecrypted = decrypt(ToString(toBinary(strBase64Value)),"mykey") />
如果strValue是要开头的字符串,strDecrypted是返回的解密字符串,strBase64Value是加密字符串,“mykey”是用于加密/解密字符串的密钥。
我的C#代码如下:
private string ConvertString(string string1, string string2)
{
byte[] key = ASCIIEncoding.ASCII.GetBytes(string1);
byte[] encryptedData = Convert.FromBase64String(string2);
Aes aes = Aes.Create();
aes.Mode = CipherMode.ECB;
using (var ms = new MemoryStream())
{
using (var cs = new CryptoStream(ms, aes.CreateDecryptor(key, null), CryptoStreamMode.Write))
{
cs.Write(encryptedData, 0, encryptedData.Length);
}
byte[] decryptedData = ms.ToArray();
string clearText = Encoding.ASCII.GetString(decryptedData);
return clearText;
}
}
我收到一条错误消息“指定的密钥不是此算法的有效大小。 参数名称:key“
答案 0 :(得分:3)
链接的示例使用AES,这是一种完全不同的算法。您的代码使用旧的cfmx_compat算法。标准c#库中没有等效的东西。但这里是a c# port of cfmx_compat(从开源Railo引擎中删除:)。
尽管如此,cfmx_compat
非常不安全,只是为了向后兼容而维护。我强烈建议切换到更安全的算法,如AES,等等。