coldfusion解密到c#

时间:2012-09-17 22:39:09

标签: c# coldfusion encryption

我复制并使用了此页面示例中的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“

1 个答案:

答案 0 :(得分:3)

链接的示例使用AES,这是一种完全不同的算法。您的代码使用旧的cfmx_compat算法。标准c#库中没有等效的东西。但这里是a c# port of cfmx_compat(从开源Railo引擎中删除:)。

尽管如此,cfmx_compat非常不安全,只是为了向后兼容而维护。我强烈建议切换到更安全的算法,如AES,等等。