当前位置: 首页>>代码示例>>C#>>正文


C# IBlockCipher.DecryptBlock方法代码示例

本文整理汇总了C#中IBlockCipher.DecryptBlock方法的典型用法代码示例。如果您正苦于以下问题:C# IBlockCipher.DecryptBlock方法的具体用法?C# IBlockCipher.DecryptBlock怎么用?C# IBlockCipher.DecryptBlock使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在IBlockCipher的用法示例。


在下文中一共展示了IBlockCipher.DecryptBlock方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: RunAESTests

        private static void RunAESTests(IEnumerable<string[]> tests, IBlockCipher aes)
        {
            foreach (var test in tests)
            {
                var plain = test[0];
                var cipher = test[1];

                // encryption
                var plainInput = HexConverter.FromHex(plain);
                var actual = new byte[aes.BlockLength];

                aes.EncryptBlock(plainInput, 0, actual, 0);

                Assert.AreEqual(cipher, HexConverter.ToHex(actual));

                // decryption
                var cipherInput = HexConverter.FromHex(cipher);
                actual = new byte[aes.BlockLength];
                aes.DecryptBlock(cipherInput, 0, actual, 0);

                Assert.AreEqual(plain, HexConverter.ToHex(actual));
            }
        }
开发者ID:will14smith,项目名称:Crypto,代码行数:23,代码来源:AESCipherTests.cs

示例2: TestIO

        private void TestIO(IBlockCipher InCipher, IBlockCipher OutCipher, byte[] Key, byte[] Input, byte[] Output)
        {
            byte[] outBytes = new byte[Output.Length];
            byte[] inBytes = new byte[Input.Length];

            // 1: test initialization
            try
            {
                OutCipher.Initialize(true, new KeyParams(Key));
            }
            catch
            {
                throw new Exception(OutCipher.Name + ": IO-1E: Initialization Failure");
            }

            try
            {
                InCipher.Initialize(false, new KeyParams(Key));
            }
            catch
            {
                throw new Exception(InCipher.Name + ": IO-1D: Initialization Failure");
            }

            // 2: EncryptBlock
            try
            {
                OutCipher.EncryptBlock(Input, outBytes);
            }
            catch (IOException Ex)
            {
                throw new Exception(OutCipher.Name + ": IO-4: Processing Failure " + Ex.Message);
            }

            // not equal
            if (Compare.AreEqual(Output, outBytes) == false)
                throw new Exception(OutCipher.Name + ": IO-4: EncryptArray: Arrays are not equal!");

            // 3: DecryptBlock
            try
            {
                InCipher.DecryptBlock(outBytes, inBytes);
            }
            catch (Exception Ex)
            {
                throw new Exception(InCipher.Name + ": IO-D5: DecryptArray Failure " + Ex.Message);
            }

            if (Compare.AreEqual(Input, inBytes) == false)
                throw new Exception(InCipher.Name + ": IO-D5: Arrays are not equal!");

            // 4: EncryptBlock
            try
            {
                OutCipher.EncryptBlock(Input, 0, outBytes, 0);
            }
            catch (IOException Ex)
            {
                throw new Exception(OutCipher.Name + ": IO-6: Processing Failure " + Ex.Message);
            }

            // not equal
            if (Compare.AreEqual(Output, outBytes) == false)
                throw new Exception(OutCipher.Name + ": IO-6: EncryptArray: Arrays are not equal!");

            // 5: DecryptBlock
            try
            {
                InCipher.DecryptBlock(outBytes, 0, inBytes, 0);
            }
            catch (Exception Ex)
            {
                throw new Exception(InCipher.Name + ": IO-D7: DecryptArray Failure " + Ex.Message);
            }

            if (Compare.AreEqual(Input, inBytes) == false)
                throw new Exception(InCipher.Name + ": IO-D7: Arrays are not equal!");
        }
开发者ID:modulexcite,项目名称:CEX,代码行数:78,代码来源:IOTest.cs


注:本文中的IBlockCipher.DecryptBlock方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。