将decrypt方法转换为sql

时间:2014-02-19 23:33:15

标签: c# sql sql-server encryption

我正在尝试复制用C#编写的加密函数,但是在SQL Server中执行。

这是C#中的方法:

public static string Encrypt(string plainText)
    {
        byte[] plainTextBytes = Encoding.UTF8.GetBytes(plainText);

        byte[] keyBytes = new Rfc2898DeriveBytes(PasswordHash, Encoding.ASCII.GetBytes(SaltKey)).GetBytes(256 / 8);
        var symmetricKey = new RijndaelManaged() { Mode = CipherMode.CBC, Padding = PaddingMode.Zeros };
        var encryptor = symmetricKey.CreateEncryptor(keyBytes, Encoding.ASCII.GetBytes(VIKey));

        byte[] cipherTextBytes;

        using (var memoryStream = new MemoryStream())
        {
            using (var cryptoStream = new CryptoStream(memoryStream, encryptor, CryptoStreamMode.Write))
            {
                cryptoStream.Write(plainTextBytes, 0, plainTextBytes.Length);
                cryptoStream.FlushFinalBlock();
                cipherTextBytes = memoryStream.ToArray();
                cryptoStream.Close();
            }
            memoryStream.Close();
        }
        return HttpUtility.UrlEncode(Convert.ToBase64String(cipherTextBytes));
    }

2 个答案:

答案 0 :(得分:0)

我认为你选择了一个复杂的解决方案!

您是否可以通过SQL中的Web服务调用C#加密来解决此问题?像这样example

答案 1 :(得分:0)

您可以尝试SQL Server扩展存储过程。使用它可以从SQL Server中调用C#方法。检查http://technet.microsoft.com/en-us/library/ms164653.aspx此网址。

重写SQL Server中的C#代码很复杂,最好使用Extended SP。