中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

.NET中常見的加解密算法有哪些

發布時間:2022-03-09 13:47:26 來源:億速云 閱讀:173 作者:iii 欄目:開發技術

這篇文章主要講解了“.NET中常見的加解密算法有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“.NET中常見的加解密算法有哪些”吧!

    一、MD5不可逆加密

    不可逆加密是指將原文加密成密文以后,無法將密文解密成原文。

    MD5的算法是公開的,無論是哪種語言,只要需要加密的字符串是相同的,那么經過MD5加密以后生成的結果都是一樣的。

    .NET框架中已經幫我們實現好了MD5加密,請看下面的例子:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Security.Cryptography;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace MyEncriptDemo
    {
        public class MD5Encrypt
        {
            #region MD5
            /// <summary>
            /// MD5加密,和動網上的16/32位MD5加密結果相同,
            /// 使用的UTF8編碼
            /// </summary>
            /// <param name="source">待加密字串</param>
            /// <param name="length">16或32值之一,其它則采用.net默認MD5加密算法</param>
            /// <returns>加密后的字串</returns>
            public static string Encrypt(string source, int length = 32)//默認參數
            {
                if (string.IsNullOrEmpty(source)) return string.Empty;
                HashAlgorithm provider = CryptoConfig.CreateFromName("MD5") as HashAlgorithm;
                byte[] bytes = Encoding.UTF8.GetBytes(source);//這里需要區別編碼的
                byte[] hashValue = provider.ComputeHash(bytes);
                StringBuilder sb = new StringBuilder();
                switch (length)
                {
                    case 16://16位密文是32位密文的9到24位字符
                        for (int i = 4; i < 12; i++)
                        {
                            sb.Append(hashValue[i].ToString("x2"));
                        }
                        break;
                    case 32:
                        for (int i = 0; i < 16; i++)
                        {
                            sb.Append(hashValue[i].ToString("x2"));
                        }
                        break;
                    default:
                        for (int i = 0; i < hashValue.Length; i++)
                        {
                            sb.Append(hashValue[i].ToString("x2"));
                        }
                        break;
                }
                return sb.ToString();
            }
            #endregion MD5
        }
    }

    Main()方法調用:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace MyEncriptDemo
    {
        class Program
        {
            static void Main(string[] args)
            {
                // MD5
                Console.WriteLine(MD5Encrypt.Encrypt("1"));
                Console.WriteLine(MD5Encrypt.Encrypt("1"));
                Console.WriteLine(MD5Encrypt.Encrypt("123456孫悟空"));
                Console.WriteLine(MD5Encrypt.Encrypt("113456孫悟空"));
                Console.WriteLine(MD5Encrypt.Encrypt("113456孫悟空113456孫悟空113456孫悟空113456孫悟空113456孫悟空113456孫悟空113456孫悟空"));
    
                Console.ReadKey();
            }
        }
    }

    結果:

    .NET中常見的加解密算法有哪些

     應用:

    1、校驗密碼

    從上面的例子中可以看出,只要字符串相同,那么加密以后的結果就是一樣的,利用MD5的這個特性,可以用來做密碼校驗。在注冊的時候把密碼用MD5加密然后保存到數據庫里面,數據庫里面保存的是密文,別人無法看到。登錄的時候,在把密碼經過MD5加密,然后用加密后的密文和數據庫里面保存的密文進行比對,如果相同,則證明密碼是一樣的;如果不同,證明密碼是錯誤的。

    注意:MD5是不能解密的,網上的解密都是基于撞庫原理的:即將原文和密文保存到數據庫中,每次利用密文去和數據庫里保存的密文進行比對,如果比對成功,則解密了。為了防止撞庫,可以使密碼復雜一些,例如加鹽:即在密碼的后面加上一段后綴然后加密后在保存到數據庫。登錄的時候,在密碼后面加上同樣的后綴,然后加密以后和數據庫保存的密碼進行比對。

    2、防篡改

    例如下載VS安裝文件,官網下載的文件才是權威的,但是有時會去系統之家這一類的網站下載,如何保證在系統之家下載的安裝文件和官網發布的文件是一樣的呢?這時就可以利用MD5進行判斷。官方在發布VS安裝文件的同時,也會發布一個根據該文件生成的MD5碼,在系統之家下載完安裝文件以后,可以對該安裝文件進行一次MD5加密,然后比對官方發布的MD5碼和生成的MD5碼,如果相同,則證明下載的文件就是官方方便的。那么如何對文件進行MD5呢?請看下面的例子:

    using System;
    using System.Collections.Generic;
    using System.IO;
    using System.Linq;
    using System.Security.Cryptography;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace MyEncriptDemo
    {
        public class MD5Encrypt
        {
            #region MD5
            /// <summary>
            /// MD5加密,和動網上的16/32位MD5加密結果相同,
            /// 使用的UTF8編碼
            /// </summary>
            /// <param name="source">待加密字串</param>
            /// <param name="length">16或32值之一,其它則采用.net默認MD5加密算法</param>
            /// <returns>加密后的字串</returns>
            public static string Encrypt(string source, int length = 32)//默認參數
            {
                if (string.IsNullOrEmpty(source)) return string.Empty;
                HashAlgorithm provider = CryptoConfig.CreateFromName("MD5") as HashAlgorithm;
                byte[] bytes = Encoding.UTF8.GetBytes(source);//這里需要區別編碼的
                byte[] hashValue = provider.ComputeHash(bytes);
                StringBuilder sb = new StringBuilder();
                switch (length)
                {
                    case 16://16位密文是32位密文的9到24位字符
                        for (int i = 4; i < 12; i++)
                        {
                            sb.Append(hashValue[i].ToString("x2"));
                        }
                        break;
                    case 32:
                        for (int i = 0; i < 16; i++)
                        {
                            sb.Append(hashValue[i].ToString("x2"));
                        }
                        break;
                    default:
                        for (int i = 0; i < hashValue.Length; i++)
                        {
                            sb.Append(hashValue[i].ToString("x2"));
                        }
                        break;
                }
                return sb.ToString();
            }
            #endregion MD5
    
            #region MD5摘要
            /// <summary>
            /// 獲取文件的MD5摘要
            /// </summary>
            /// <param name="fileName"></param>
            /// <returns></returns>
            public static string AbstractFile(string fileName)
            {
                using (FileStream file = new FileStream(fileName, FileMode.Open))
                {
                    return AbstractFile(file);
                }
            }
    
            /// <summary>
            /// 根據stream獲取文件摘要
            /// </summary>
            /// <param name="stream"></param>
            /// <returns></returns>
            public static string AbstractFile(Stream stream)
            {
                MD5 md5 = new MD5CryptoServiceProvider();
                byte[] retVal = md5.ComputeHash(stream);
    
                StringBuilder sb = new StringBuilder();
                for (int i = 0; i < retVal.Length; i++)
                {
                    sb.Append(retVal[i].ToString("x2"));
                }
                return sb.ToString();
            }
            #endregion
        }
    }

     Main()方法里面調用:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace MyEncriptDemo
    {
        class Program
        {
            static void Main(string[] args)
            {
                // MD5
                //Console.WriteLine(MD5Encrypt.Encrypt("1"));
                //Console.WriteLine(MD5Encrypt.Encrypt("1"));
                //Console.WriteLine(MD5Encrypt.Encrypt("123456孫悟空"));
                //Console.WriteLine(MD5Encrypt.Encrypt("113456孫悟空"));
                //Console.WriteLine(MD5Encrypt.Encrypt("113456孫悟空113456孫悟空113456孫悟空113456孫悟空113456孫悟空113456孫悟空113456孫悟空"));
                // 對文件進行MD5
                string md5Abstract1 = MD5Encrypt.AbstractFile(@"E:\EF一對多.txt");
                Console.WriteLine(md5Abstract1);
                string md5Abstract2 = MD5Encrypt.AbstractFile(@"E:\EF一對多 - 副本.txt");
                Console.WriteLine(md5Abstract2);
                Console.ReadKey();
            }
        }
    }

     結果:

    .NET中常見的加解密算法有哪些

    可以看出,雖然文件的名稱不同,但只要文件的內容是相同的,則生成的MD5碼就是相同的。

    3、急速秒傳

    以百度云為例:假如從百度云上面下載了一個文件,然后把這個文件在上傳到百度云就會急速秒傳。因為第一次上傳的時候,百度云會對上傳的文件進行MD5加密,然后把加密后的MD5碼保存下來。下載之后再上傳,百度云客戶端會先對文件計算MD5,然后將計算的MD5和服務器保存的MD5進行對比,如果一致就不需要在上傳了,只需要把服務器上文件的名稱修改成和上傳文件的名稱一致即可。因為上傳的文件在服務器上已經存在。(就算修改了文件名稱,但生成的MD5還是一樣的)

    4、源代碼管理工具

    源代碼管理工具實現判斷文件是否修改,也是根據MD5進行比對的。

    二、對稱可逆加密

    對稱可逆加密:可逆是指加密和解密是可逆的,即可以根據原文得到密文,也可以根據密文得到原文。對稱是指加密和解密的密鑰是相同的。下面以DES加密為例。

    在示例程序中,密鑰長度是8位的,寫在配置文件中。

    讀取配置文件獲取密鑰的代碼如下:

    using System;
    using System.Collections.Generic;
    using System.Configuration;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace MyEncriptDemo
    {
        public static class Constant
        {
            public static string DesKey = AppSettings("DesKey", "DesEncript");
    
    
            private static T AppSettings<T>(string key, T defaultValue)
            {
                var v = ConfigurationManager.AppSettings[key];
                return String.IsNullOrEmpty(v) ? defaultValue : (T)Convert.ChangeType(v, typeof(T));
            }
    
        }
    }

     加密和解密的代碼如下:

    using System;
    using System.Collections.Generic;
    using System.IO;
    using System.Linq;
    using System.Security.Cryptography;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace MyEncriptDemo
    {
        /// <summary>
        /// DES AES Blowfish
        ///  對稱加密算法的優點是速度快,
        ///  缺點是密鑰管理不方便,要求共享密鑰。
        /// 可逆對稱加密  密鑰長度8
        /// </summary>
        public class DesEncrypt
        {
            // 按照8位長度的密鑰進行加密
            private static byte[] _rgbKey = ASCIIEncoding.ASCII.GetBytes(Constant.DesKey.Substring(0, 8));
            // 對稱算法的初始化向量
            private static byte[] _rgbIV = ASCIIEncoding.ASCII.GetBytes(Constant.DesKey.Insert(0, "w").Substring(0, 8));
    
            /// <summary>
            /// DES 加密
            /// </summary>
            /// <param name="text">需要加密的值</param>
            /// <returns>加密后的結果</returns>
            public static string Encrypt(string text)
            {
                DESCryptoServiceProvider dsp = new DESCryptoServiceProvider();
                using (MemoryStream memStream = new MemoryStream())
                {
                    CryptoStream crypStream = new CryptoStream(memStream, dsp.CreateEncryptor(_rgbKey, _rgbIV), CryptoStreamMode.Write);
                    StreamWriter sWriter = new StreamWriter(crypStream);
                    sWriter.Write(text);
                    sWriter.Flush();
                    crypStream.FlushFinalBlock();
                    memStream.Flush();
                    return Convert.ToBase64String(memStream.GetBuffer(), 0, (int)memStream.Length);
                }
            }
    
            /// <summary>
            /// DES解密
            /// </summary>
            /// <param name="encryptText"></param>
            /// <returns>解密后的結果</returns>
            public static string Decrypt(string encryptText)
            {
                DESCryptoServiceProvider dsp = new DESCryptoServiceProvider();
                byte[] buffer = Convert.FromBase64String(encryptText);
    
                using (MemoryStream memStream = new MemoryStream())
                {
                    CryptoStream crypStream = new CryptoStream(memStream, dsp.CreateDecryptor(_rgbKey, _rgbIV), CryptoStreamMode.Write);
                    crypStream.Write(buffer, 0, buffer.Length);
                    crypStream.FlushFinalBlock();
                    return ASCIIEncoding.UTF8.GetString(memStream.ToArray());
                }
            }
        }
    }

    Main()方法調用:

    string strDes = "張三李四";
    string desEn1 = DesEncrypt.Encrypt(strDes);
    string desDe1 = DesEncrypt.Decrypt(desEn1);
    Console.WriteLine(strDes.Equals(desDe1));

    結果:

    .NET中常見的加解密算法有哪些

    注意:對稱可逆加密的算法是公開的。

    三、非對稱可逆加密

    非對稱可逆加密:可逆是指加密和解密是一樣,即根據原文可以得到密文,根據密文也可以得到原文。非對稱是指加密和解密的密鑰是不同的。下面以RSA加密為例:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Security.Cryptography;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace MyEncriptDemo
    {
        /// <summary>
        /// RSA ECC
        /// 可逆非對稱加密
        /// 非對稱加密算法的優點是密鑰管理很方便,缺點是速度慢。
        /// </summary>
        public class RsaEncrypt
        {
            /// <summary>
            /// 獲取加密/解密對
            /// 給你一個,是無法推算出另外一個的
            ///
            /// Encrypt   Decrypt
            /// </summary>
            /// <returns>Encrypt   Decrypt</returns>
            public static KeyValuePair<string, string> GetKeyPair()
            {
                RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();
                string publicKey = RSA.ToXmlString(false);
                string privateKey = RSA.ToXmlString(true);
                return new KeyValuePair<string, string>(publicKey, privateKey);
            }
    
            /// <summary>
            /// 加密:內容+加密key
            /// </summary>
            /// <param name="content"></param>
            /// <param name="encryptKey">加密key</param>
            /// <returns></returns>
            public static string Encrypt(string content, string encryptKey)
            {
                RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
                rsa.FromXmlString(encryptKey);
                UnicodeEncoding ByteConverter = new UnicodeEncoding();
                byte[] DataToEncrypt = ByteConverter.GetBytes(content);
                byte[] resultBytes = rsa.Encrypt(DataToEncrypt, false);
                return Convert.ToBase64String(resultBytes);
            }
    
            /// <summary>
            /// 解密  內容+解密key
            /// </summary>
            /// <param name="content"></param>
            /// <param name="decryptKey">解密key</param>
            /// <returns></returns>
            public static string Decrypt(string content, string decryptKey)
            {
                byte[] dataToDecrypt = Convert.FromBase64String(content);
                RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();
                RSA.FromXmlString(decryptKey);
                byte[] resultBytes = RSA.Decrypt(dataToDecrypt, false);
                UnicodeEncoding ByteConverter = new UnicodeEncoding();
                return ByteConverter.GetString(resultBytes);
            }
    
    
            /// <summary>
            /// 可以合并在一起的,,每次產生一組新的密鑰
            /// </summary>
            /// <param name="content"></param>
            /// <param name="encryptKey">加密key</param>
            /// <param name="decryptKey">解密key</param>
            /// <returns>加密后結果</returns>
            private static string Encrypt(string content, out string publicKey, out string privateKey)
            {
                RSACryptoServiceProvider rsaProvider = new RSACryptoServiceProvider();
                publicKey = rsaProvider.ToXmlString(false);
                privateKey = rsaProvider.ToXmlString(true);
    
                UnicodeEncoding ByteConverter = new UnicodeEncoding();
                byte[] DataToEncrypt = ByteConverter.GetBytes(content);
                byte[] resultBytes = rsaProvider.Encrypt(DataToEncrypt, false);
                return Convert.ToBase64String(resultBytes);
            }
        }
    }

    Main()方法調用:

    // 獲取加密和解密的密鑰
    KeyValuePair<string, string> encryptDecrypt = RsaEncrypt.GetKeyPair();
    string strValue = "RsaDemo";
    string rsaEn1 = RsaEncrypt.Encrypt(strValue, encryptDecrypt.Key);//key是加密的
    string rsaDe1 = RsaEncrypt.Decrypt(rsaEn1, encryptDecrypt.Value);//value 解密的   不能反過來用的
    Console.WriteLine(strValue.Equals(rsaDe1));

    結果:

    .NET中常見的加解密算法有哪些

    注意:

    1、加密鑰和解密鑰是根據功能來劃分的。

    2、私鑰和公鑰是根據鑰匙的公開程度來劃分的,加密鑰可以作為公鑰或者私鑰、解密鑰也可以作為公鑰或者私鑰。

    感謝各位的閱讀,以上就是“.NET中常見的加解密算法有哪些”的內容了,經過本文的學習后,相信大家對.NET中常見的加解密算法有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    怀仁县| 博兴县| 息烽县| 张家川| 舞钢市| 台东市| 旬阳县| 泰安市| 乌拉特后旗| 嘉善县| 天气| 丘北县| 潼关县| 达日县| 株洲县| 长寿区| 伊宁市| 拉萨市| 梨树县| 淮安市| 雅江县| 当雄县| 定远县| 仙居县| 扶余县| 杨浦区| 杭锦旗| 弥勒县| 万荣县| 海南省| 外汇| 怀化市| 伽师县| 双江| 平安县| 五常市| 当阳市| 乃东县| 孙吴县| 曲周县| 德格县|