广告
返回顶部
首页 > 资讯 > 精选 >.NET中常见的加解密算法有哪些
  • 755
分享到

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

2023-06-29 10:06:14 755人浏览 独家记忆
摘要

这篇文章主要讲解了“.net中常见的加解密算法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“.NET中常见的加解密算法有哪些”吧!一、MD5不可逆加密不可逆加密是指将原文加密成密文以后

这篇文章主要讲解了“.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中常见的加解密算法有哪些

    注意:

    加密钥和解密钥是根据功能来划分的。

    私钥和公钥是根据钥匙的公开程度来划分的,加密钥可以作为公钥或者私钥、解密钥也可以作为公钥或者私钥。

    感谢各位的阅读,以上就是“.NET中常见的加解密算法有哪些”的内容了,经过本文的学习后,相信大家对.NET中常见的加解密算法有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    --结束END--

    本文标题: .NET中常见的加解密算法有哪些

    本文链接: https://www.lsjlt.com/news/324327.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • .NET中常见的加解密算法有哪些
      这篇文章主要讲解了“.NET中常见的加解密算法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“.NET中常见的加解密算法有哪些”吧!一、MD5不可逆加密不可逆加密是指将原文加密成密文以后...
      99+
      2023-06-29
    • .NET中常见的加解密算法详解
      目录一、MD5不可逆加密1、校验密码2、防篡改3、急速秒传4、源代码管理工具二、对称可逆加密三、非对称可逆加密一、MD5不可逆加密 不可逆加密是指将原文加密成密文以后,无法将密文解密...
      99+
      2022-11-13
    • Python中常见的加密解密算法有哪些
      1.url encode加密简介:当url地址含有中文,或者参数有中文的时候,这个算是很正常了,但是把这样的url作为参数传递的时候(最常见的callback),需要把一些中文甚至'/'做一下编码转换。# -*- codin...
      99+
      2023-05-16
      Python
    • Golang中常见加密算法有哪些
      本文小编为大家详细介绍“Golang中常见加密算法有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“Golang中常见加密算法有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.md5 加密&md...
      99+
      2023-07-05
    • Linux下常见的加密算法有哪些
      这篇文章将为大家详细讲解有关Linux下常见的加密算法有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Linux系统中常见的加密算法有:对称加密;非对称加密;单向加密;SSL/TLS;秘钥交换等。1、...
      99+
      2023-06-27
    • Python爬虫中常见的加密算法有哪些
      这篇文章主要讲解了“Python爬虫中常见的加密算法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python爬虫中常见的加密算法有哪些”吧!1. 基础常识首先我们需要明白的是,什么是...
      99+
      2023-07-02
    • java常见的加密方法有哪些
      Java常见的加密方法有以下几种:1. 对称加密:对称加密算法使用相同的密钥对数据进行加密和解密,常见的对称加密算法有DES、3DE...
      99+
      2023-09-06
      java
    • PHP中常用的加密算法有哪些?
      随着互联网的发展,数据安全已成为我们日常工作中必须关注的严肃问题。针对敏感的个人信息或商业数据,加密变得尤为重要。在PHP开发中,一些加密算法被广泛应用,下面我们就来了解一下PHP中常用的加密算法。一、Base64编码Base64编码常用于...
      99+
      2023-05-14
      PHP 加密算法 常用
    • web中常用的加密算法有哪些
      今天小编给大家分享一下web中常用的加密算法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。 加密算法我们整体...
      99+
      2023-06-17
    • 有哪些Go加密解密算法
      这篇文章主要讲解了“有哪些Go加密解密算法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“有哪些Go加密解密算法”吧!md5MD5信息摘要算法是一种被广泛使用的密码散列函数,可以产生出一个12...
      99+
      2023-06-16
    • Python3常见加密计数方法有哪些
      这篇文章主要介绍了Python3常见加密计数方法有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python3常见加密计数方法有哪些文章都会有所收获,下面我们一起来看看吧。Python 3 的标准库中没多少...
      99+
      2023-06-27
    • Python中有哪些常见的加密方式
      Python中有哪些常见的加密方式,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。前言我们所说的加密方式,都是对二进制编码的格式进行加密的,对应到Python中,则是我们的B...
      99+
      2023-06-02
    • Python中有哪些常见的加密操作
      这篇文章给大家介绍Python中有哪些常见的加密操作,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。hashlib加密import hashlib # 有很多种加密方式,md5,sha1等等...
      99+
      2023-06-13
    • java中的加密算法有哪些
      java中的加密算法有哪些?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。java中的加密算法有哪些import java.security.MessageDigest...
      99+
      2023-05-31
      java 加密算法 ava
    • C#中常见的文件加密和解密算法问题
      C#中常见的文件加密和解密算法问题,需要具体代码示例在现代计算机应用中,数据的保护和安全显得尤为重要。文件加密和解密算法是一种常用的数据安全保护措施,可以确保文件在传输和存储过程中不被未授权的人员访问和修改。本文将探讨C#中常见的文件加密和...
      99+
      2023-10-22
      算法 解密 C#: 文件加密
    • Python中有哪些加密算法
      这期内容当中小编将会给大家带来有关Python中有哪些加密算法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。MD5加密全称:MD5消息摘要算法(英语:MD5 Message-Digest  Al...
      99+
      2023-06-16
    • java加密算法有哪些
      java中常用的加密算法有:1.BASE64算法,二进制数据;2.MD5算法,散列函数;3.SHA算法,消息摘要算法;4.RSA算法,用于加密和数字签名的算法;5.DES算法,对称密码体制加密算法;6.PBE算法,基于口令的加密算法;7.D...
      99+
      2022-10-07
    • 常用的数据加密算法主要有哪些
      常见的数据加密算法有以下几种DES算法DES加密算法是一种分组密码,以64位为分组对数据加密,它的密钥长度是56位,加密解密用同一算法。DES加密算法是对密钥进行保密,而公开算法,包括加密和解密算法。MD5算法MD5为计算机安全领域广泛使用...
      99+
      2022-10-18
    • Java中五种最常见加密算法
      1 前言 大家平时的工作中,可能也在很多地方用到了加密、解密,比如: 用户的密码不能明文存储,要存储加密后的密文 用户的银行卡号、身份证号之类的敏感数据,需要加密传输 还有一些重要接口,比如支付...
      99+
      2023-09-14
      java 开发语言 加密
    • Java中常见的限流算法有哪些
      这篇“Java中常见的限流算法有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java中常见的限流算法有哪些”文章吧。0...
      99+
      2023-07-05
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作