當前位置: 首頁>>代碼示例>>C#>>正文


C# AesManaged.Dispose方法代碼示例

本文整理匯總了C#中System.Security.Cryptography.AesManaged.Dispose方法的典型用法代碼示例。如果您正苦於以下問題:C# AesManaged.Dispose方法的具體用法?C# AesManaged.Dispose怎麽用?C# AesManaged.Dispose使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Security.Cryptography.AesManaged的用法示例。


在下文中一共展示了AesManaged.Dispose方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Decrypt

        public static String Decrypt(String privateKey, String salt, ApiObject request)
        {
            var aes = new AesManaged();
            aes.IV = Encoding.Unicode.GetBytes(salt);
            aes.Key = RSADecrypt(privateKey, request.Key);

            String decrypted = null;

            try
            {
                var decryptor = aes.CreateDecryptor();

                using (MemoryStream msDecrypt = new MemoryStream(request.Data))
                {
                    using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
                    {
                        using (StreamReader srDecrypt = new StreamReader(csDecrypt))
                        {

                            // Read the decrypted bytes from the decrypting stream
                            // and place them in a string.
                            decrypted = srDecrypt.ReadToEnd();
                        }
                    }
                }
            }
            catch (Exception ex)
            {

            }
            finally
            {
                aes.Dispose();
            }

            return decrypted;
        }
開發者ID:yamborko,項目名稱:ATM,代碼行數:37,代碼來源:CryptoHelper.cs

示例2: Encrypt

        void Encrypt(OnCommandArgs args, string[] inMsg)
        {
            if (inMsg.Length < 3){
                _ircInterface.Client.SendMessage(SendType.Message, args.Source, args.Nick + " the syntax for this command is .encrypt <key> <data>");
                return;
            }
            try{
                var key = AsciiToBase10(inMsg[1].ToCharArray());
                var msg = AssembleMessage(inMsg.Skip(2).ToList());
                msg = msg.Remove(msg.Length - 1);
                var msgByte = AsciiToBase10(msg.ToCharArray());

                if (msgByte.Length%16 != 0){
                    var paddedLen = (msgByte.Length/16 + 1)*16;
                    msgByte = PKCS7(msgByte, paddedLen);
                }

                var aes = new AesManaged();
                aes.KeySize = 128;
                aes.Mode = CipherMode.CBC;
                aes.Key = PKCS7(key, 16);
                aes.Padding = PaddingMode.None;
                aes.IV = new byte[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};

                var memStrm = new MemoryStream(msgByte.Length);
                var cryptStrm = new CryptoStream(memStrm, aes.CreateEncryptor(), CryptoStreamMode.Write);
                cryptStrm.Write(msgByte, 0, msgByte.Length);

                var ret = memStrm.ToArray();
                aes.Dispose();
                cryptStrm.Dispose();
                memStrm.Dispose();

                var retb10 = new string(Convert.ToBase64String(ret).ToCharArray());
                _ircInterface.Client.SendMessage(SendType.Message, args.Source, args.Nick + ": " + retb10);
            }
            catch{
                _ircInterface.Client.SendMessage(SendType.Message, args.Source, args.Nick + ": something went wrong during encryption.");
            }
        }
開發者ID:bsamuels453,項目名稱:Pikatwo,代碼行數:40,代碼來源:Encryptor.cs

示例3: Decrypt

        void Decrypt(OnCommandArgs args, string[] inMsg)
        {
            if (inMsg.Length < 3){
                _ircInterface.Client.SendMessage(SendType.Message, args.Source, args.Nick + " the syntax for this command is .decrypt <key> <data>");
                return;
            }
            try{
                var key = AsciiToBase10(inMsg[1].ToCharArray());
                var msgByte = Convert.FromBase64CharArray(inMsg[2].ToCharArray(), 0, inMsg[2].Length);

                var aes = new AesManaged();
                aes.Mode = CipherMode.CBC;
                aes.IV = new byte[]{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
                aes.KeySize = 128;
                var keyPad = PKCS7(key, 16);
                aes.Key = keyPad;
                aes.Padding = PaddingMode.None;

                var memStrm = new MemoryStream(msgByte.Length);
                var cryptStrm = new CryptoStream(memStrm, aes.CreateDecryptor(), CryptoStreamMode.Write);
                cryptStrm.Write(msgByte, 0, msgByte.Length);

                var ret = memStrm.ToArray();
                aes.Dispose();
                cryptStrm.Dispose();
                memStrm.Dispose();
                ret = StripPKCS7(ret);
                var retStr = new string(Base10ToAscii(ret));
                _ircInterface.Client.SendMessage(SendType.Message, args.Source, args.Nick + ": " + retStr);
            }
            catch{
                _ircInterface.Client.SendMessage
                    (SendType.Message, args.Source, args.Nick + ": something went wrong during decryption. did you change the encrypted string?");
            }
        }
開發者ID:bsamuels453,項目名稱:Pikatwo,代碼行數:35,代碼來源:Encryptor.cs

示例4: Encrypt

        public static ApiObject Encrypt(String publicKey, String salt, String dataToEncrypt)
        {
            var aes = new AesManaged();
            aes.IV = Encoding.Unicode.GetBytes(salt);

            Byte[] key = aes.Key;
            Byte[] encrypted = null;

            try
            {
                var encryptor = aes.CreateEncryptor();

                // Create the streams used for encryption.
                using (MemoryStream msEncrypt = new MemoryStream())
                {
                    using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
                    {
                        using (StreamWriter swEncrypt = new StreamWriter(csEncrypt))
                        {

                            //Write all data to the stream.
                            swEncrypt.Write(dataToEncrypt);
                        }
                        encrypted = msEncrypt.ToArray();
                    }
                }
            } catch(Exception ex)
            {

            }
            finally
            {
                aes.Dispose();
            }

            return new ApiObject { Data = encrypted, Key =  RSAEncrypt(publicKey, key) };
        }
開發者ID:yamborko,項目名稱:ATM,代碼行數:37,代碼來源:CryptoHelper.cs


注:本文中的System.Security.Cryptography.AesManaged.Dispose方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。