【.NET】.NET加密与解密C#

文章目录


1、加密

public class Encrypts
    {
   
        ///   <summary> 
        ///   构造方法 
        ///   </summary> 
        public Encrypts()
        {
   
        }
        ///   <summary> 
        ///   使用缺省密钥字符串加密 
        ///   </summary> 
        ///   <param   name= "original "> 明文 </param> 
        ///   <returns> 密文 </returns> 
        public static string Encrypt(string original)
        {
   
            return Encrypt(original, "haha");
        }
        ///   <summary> 
        ///   使用缺省密钥解密 
        ///   </summary> 
        ///   <param   name= "original "> 密文 </param> 
        ///   <returns> 明文 </returns> 
        public static string Decrypt(string original)
        {
   
            try
            {
   
                return Decrypt(original, "haha", System.Text.Encoding.Default);
            }
            catch
            {
   
                return ("");
            }
        }
        ///   <summary> 
        ///   使用给定密钥解密 
        ///   </summary> 
        ///   <param   name= "original "> 密文 </param> 
        ///   <param   name= "key "> 密钥 </param> 
        ///   <returns> 明文 </returns> 
        public static string Decrypt(string original, string key)
        {
   
            return Decrypt(original, key, System.Text.Encoding.Default);
        }
        ///   <summary> 
        ///   使用缺省密钥解密,返回指定编码方式明文 
        ///   </summary> 
        ///   <param   name= "original "> 密文 </param> 
        ///   <param   name= "encoding "> 编码方式 </param> 
        ///   <returns> 明文 </returns> 
        public static string Decrypt(string original, Encoding encoding)
        {
   
            return Decrypt(original, "haha", encoding);
        }
        ///   <summary> 
        ///   使用给定密钥加密 
        ///   </summary> 
        ///   <param   name= "original "> 原始文字 </param> 
        ///   <param   name= "key "> 密钥 </param> 
        ///   <param   name= "encoding "> 字符编码方案 </param> 
        ///   <returns> 密文 </returns> 
        public static string Encrypt(string original, string key)
        {
   
            byte[] buff = System.Text.Encoding.Default.GetBytes(original);
            byte[] kb = System.Text.Encoding.Default.GetBytes(key);
            return Convert.ToBase64String(Encrypt(buff, kb));
        }

        ///   <summary> 
        ///   使用给定密钥解密 
        ///   </summary> 
        ///   <param   name= "encrypted "> 密文 </param> 
        ///   <param   name= "key "> 密钥 </param> 
        ///   <param   name= "encoding "> 字符编码方案 </param> 
        ///   <returns> 明文 </returns> 
        public static string Decrypt(string encrypted, string key, Encoding encoding)
        {
   
            byte[] buff = Convert.FromBase64String(encrypted);
            byte[] kb = System.Text.Encoding.Default.GetBytes(key);
            return encoding.GetString(Decrypt(buff, kb));
        }
        ///   <summary> 
        ///   生成MD5摘要 
        ///   </summary> 
        ///   <param   name= "original "> 数据源 </param> 
        ///   <returns> 摘要 </returns> 
        public static byte[] MakeMD5(byte[] original)
        {
   
            MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();
            byte[] keyhash = hashmd5.ComputeHash(original);
            hashmd5 = null;
            return keyhash;
        }

        ///   <summary> 
        ///   使用给定密钥加密 
        ///   </summary> 
        ///   <param   name= "original "> 明文 </param> 
        ///   <param   name= "key "> 密钥 </param> 
        ///   <returns> 密文 </returns> 
        public static byte[] Encrypt(byte[] original, byte[] key)
        {
   
            TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();
            des.Key = MakeMD5(key);
            des.Mode = CipherMode.ECB;

            return des.CreateEncryptor().TransformFinalBlock(original, 0, original.Length);
        }

        ///   <summary> 
        ///   使用给定密钥解密数据 
        ///   </summary> 
        ///   <param   name= "encrypted "> 密文 </param> 
        ///   <param   name= "key "> 密钥 </param> 
        ///   <returns> 明文 </returns> 
        public static byte[] Decrypt(byte[] encrypted, byte[] key)
        {
   
            TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();
            des.Key = MakeMD5(key);
            des.Mode = CipherMode.ECB;

            return des.CreateDecryptor().TransformFinalBlock(encrypted, 0, encrypted.Length);
        }

        ///   <summary> 
        ///   使用给定密钥加密 
        ///   </summary> 
        ///   <param   name= "original "> 原始数据 </param> 
        ///   <param   name= "key "> 密钥 </param> 
        ///   <returns> 密文 </returns> 
        public static byte[] Encrypt(byte[] original)
        {
   
            byte[] key = System.Text.Encoding.Default.GetBytes("haha");
            return Encrypt(original, key);
        }

        ///   <summary> 
        ///   使用缺省密钥解密数据 
        ///   </summary> 
        ///   <param   name= "encrypted "> 密文 </param> 
        ///   <param   name= "key "> 密钥 </param> 
        ///   <returns> 明文 </returns> 
        public static byte[] Decrypt(byte[] encrypted)
        {
   
            byte[] key = System.Text.Encoding.Default.GetBytes("haha");
            return Decrypt(encrypted, key);
        }

    }

2、解密

public class EncryDecry
    {
   

        #region 加密

        /// <summary>
        /// 加密
        /// </summary>
        /// <param name="data">明文</param>
        /// <param name="Key_64">Key_64 长度8位</param>
        /// <param name="Iv_64">Key_64 长度8位</param>
        /// <returns></returns>

        public static string Encrypt(string data, string Key_64, string Iv_64)
        {
   

            string KEY_64 = Key_64;// "12345678";

            string IV_64 = Iv_64;// "12345678";

            try
            {
   

                byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(KEY_64);

                byte[] byIV = System.Text.ASCIIEncoding.ASCII.GetBytes(IV_64);

                DESCryptoServiceProvider cryptoProvider = new DESCryptoServiceProvider();

                int i = cryptoProvider.KeySize;

                MemoryStream ms = new MemoryStream();

                CryptoStream cst = new CryptoStream(ms, cryptoProvider.CreateEncryptor(byKey, byIV), CryptoStreamMode.Write);

                StreamWriter sw = new StreamWriter(cst);

                sw.Write(data);

                sw.Flush();

                cst.FlushFinalBlock();

                sw.Flush();

                return Convert.ToBase64String(ms.GetBuffer(), 0, (int)ms.Length);

            }

            catch (Exception x)
            {
   

                return x.Message;

            }

        }

        #endregion


        #region 解密

        
        /// <summary>
        /// 解密
        /// </summary>
        /// <param name="data">密文</param>
        /// <param name="Key_64">Key_64 长度8位</param>
        /// <param name="Iv_64">Key_64 长度8位</param>
        /// <returns></returns>
        public static string Decrypt(string data, string Key_64, string Iv_64)
        {
   

            string KEY_64 = Key_64;// "12345678";密钥

            string IV_64 = Iv_64;// "12345678"; 向量

            try
            {
   

                byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(KEY_64);

                byte[] byIV = System.Text.ASCIIEncoding.ASCII.GetBytes(IV_64);

                byte[] byEnc;

                byEnc = Convert.FromBase64String(data); //把需要解密的字符串转为8位无符号数组

                DESCryptoServiceProvider cryptoProvider = new DESCryptoServiceProvider();

                MemoryStream ms = new MemoryStream(byEnc);

                CryptoStream cst = new CryptoStream(ms, cryptoProvider.CreateDecryptor(byKey, byIV), CryptoStreamMode.Read);

                StreamReader sr = new StreamReader(cst);

                return sr.ReadToEnd();

            }

            catch (Exception x)
            {
   

                return x.Message;

            }

        }

        #endregion

    }

相关推荐

  1. 【.NET】.NET加密解密C#

    2023-12-21 02:26:02       44 阅读
  2. c# 文本加密解密

    2023-12-21 02:26:02       41 阅读
  3. c# 加密解密帮助类

    2023-12-21 02:26:02       29 阅读
  4. C#加密解密、哈希

    2023-12-21 02:26:02       19 阅读
  5. 加密解密】【01】网络安全体系

    2023-12-21 02:26:02       9 阅读
  6. C语言】对称密码——栅栏的加密解密

    2023-12-21 02:26:02       17 阅读
  7. C语言】单表交换密码的加密解密

    2023-12-21 02:26:02       12 阅读

最近更新

  1. js list to tree

    2023-12-21 02:26:02       0 阅读
  2. 02更新用户在线状态

    2023-12-21 02:26:02       0 阅读
  3. CSS魔法:link与@import的秘密较量

    2023-12-21 02:26:02       0 阅读
  4. 第12章:软件系统分析与设计

    2023-12-21 02:26:02       0 阅读
  5. Rust入门实战 编写Minecraft启动器#2建立资源模型

    2023-12-21 02:26:02       1 阅读
  6. three.js利用着色器实现波浪效果

    2023-12-21 02:26:02       1 阅读
  7. Python pdfplumber库:轻松解析PDF文件

    2023-12-21 02:26:02       1 阅读

热门阅读

  1. CSS

    CSS

    2023-12-21 02:26:02      41 阅读
  2. 计算机网络第二章课后习题2-16解析

    2023-12-21 02:26:02       30 阅读
  3. Golang基础教程

    2023-12-21 02:26:02       43 阅读
  4. 黑豹程序员-HTTP返回状态码

    2023-12-21 02:26:02       29 阅读
  5. 【ValueError: RSA key format is not supported】

    2023-12-21 02:26:02       42 阅读
  6. 一文学会 Apache Zeppelin

    2023-12-21 02:26:02       38 阅读
  7. JVM- 为什么G1垃圾回收器需要有大对象区

    2023-12-21 02:26:02       37 阅读
  8. ETL-从1学到100(1/100):ETL涉及到的名词解释

    2023-12-21 02:26:02       35 阅读
  9. TensorFlow 入门:Hello TensorFlow 编程

    2023-12-21 02:26:02       40 阅读