DES的加密解密

DES的加密解密


          DES加密算法是一种对称加密算法,很可能是使用最广泛的密钥系统,特别是在保护金融数据的安全中,最初开发的DEA是嵌入硬件中的。

          在VS中的使用非常的简单,首先引用两个命名空间,然后,需要的设置两个参数,一个是key值秘钥,一个是iv向量。

          引用命名空间

          usingSystem.IO;

          usingSystem.Security.Cryptography;

          加密解密函数

<span style="font-size:24px;">//加密函数
        public static string Encrypt(string sourceString, string key, string iv)
        {
            try
            {
                byte[] btKey = Encoding.UTF8.GetBytes(key);
                byte[] btIV = Encoding.UTF8.GetBytes(iv);
                DESCryptoServiceProvider des = new DESCryptoServiceProvider();

                using (MemoryStream ms = new MemoryStream())
                {
                    byte[] inData = Encoding.UTF8.GetBytes(sourceString);
                    try
                    {
                        using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(btKey, btIV), CryptoStreamMode.Write))
                        {
                            cs.Write(inData, 0, inData.Length);
                            cs.FlushFinalBlock();
                        }
                        return Convert.ToBase64String(ms.ToArray());
                    }
                    catch
                    {
                        return sourceString;
                    }
                }
            }
            catch { }

            return "DES加密出错";
        }  

        //解密函数
        public static string Decrypt(string encryptedString, string key, string iv)
        {
            byte[] btKey = Encoding.UTF8.GetBytes(key);
            byte[] btIV = Encoding.UTF8.GetBytes(iv);
            DESCryptoServiceProvider des = new DESCryptoServiceProvider();

            using (MemoryStream ms = new MemoryStream())
            {
                byte[] inData = Convert.FromBase64String(encryptedString);
                try
                {
                    using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(btKey, btIV), CryptoStreamMode.Write))
                    {
                        cs.Write(inData, 0, inData.Length);
                        cs.FlushFinalBlock();
                    }

                    return Encoding.UTF8.GetString(ms.ToArray());
                }
                catch
                {
                    return encryptedString;
                }
            }
        }</span>

          添加两个控件,进行调用加密解密函数,一句话即可。

<span style="font-size:24px;">private void button1_Click(object sender, EventArgs e)
        {
            string jiamiqian = textBox1.Text;
            textBox2.Text = Encrypt(jiamiqian, "12345678", "abcdefgh");
        }

        private void button2_Click(object sender, EventArgs e)
        {
            string jiemiqian = textBox1.Text;
            textBox2.Text = Decrypt(jiemiqian, "12345678", "abcdefgh");
        }  
</span>


### DES加密解密方法概述 数据加密标准(Data Encryption Standard, DES)是一种对称加密算法,它通过一个固定的56位密钥来加密和解密数据。DES将明文分为64位的数据块,并对其进行一系列复杂的置换和替换操作以生成密文[^1]。 以下是关于DES加密解密的具体实现方式: #### 密钥长度与分组大小 DES使用的是固定长度的密钥——即56位有效密钥加上8位奇偶校验位形成64位输入密钥。每次处理的数据块也是64位长。这种设计使得DES能够快速执行加密和解密过程[^2]。 #### 加密流程描述 在加密过程中,原始消息被分割成多个64比特的小段,每一段都经过初始排列IP (Initial Permutation),随后进入由16轮迭代组成的Feistel结构,在最后一轮结束后再做一次逆向初始排列(IP^-1)[^3]。 #### 解密流程描述 由于DES采用对称密码体制,因此其解密过程实际上就是按照相反顺序重复相同的运算步骤,只是使用的子密钥次序颠倒过来而已[^4]。 下面给出Python语言中的简单示例代码展示如何利用pycryptodome库完成基本的DES加解密功能: ```python from Crypto.Cipher import DES from Crypto.Util.Padding import pad, unpad import base64 def des_encrypt(plaintext, key): cipher = DES.new(key.encode(), DES.MODE_ECB) padded_text = pad(plaintext.encode(), DES.block_size) encrypted_data = cipher.encrypt(padded_text) return base64.b64encode(encrypted_data).decode() def des_decrypt(ciphertext, key): cipher = DES.new(key.encode(), DES.MODE_ECB) decoded_ciphertext = base64.b64decode(ciphertext) decrypted_padded_data = cipher.decrypt(decoded_ciphertext) return unpad(decrypted_padded_data, DES.block_size).decode() # Example Usage key = '12345678' # Must be exactly 8 bytes long. message = "HelloWorld" ciphered_message = des_encrypt(message, key) print(f"Cipher Text: {ciphered_message}") original_message = des_decrypt(ciphered_message, key) print(f"Original Message: {original_message}") ``` 上述程序展示了基于ECB模式下的基础版DES加密/解密逻辑[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值