C#中如何使用加密算法,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
C#加密算法
MD5的全称是message-digest algorithm 5(信息-摘要算法),在90年代初由mit laboratory for computer science和rsa data security inc的ronald l. rivest开发出来,经md2、md3和md4发展而来。它的作用是让大容量信息在用数字签名软件签署私人密匙前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的大整数)。不管是md2、md4还是md5,它们都需要获得一个随机长度的信息并产生一个128位的信息摘要。虽然这些算法的结构或多或少有些相似,但md2的设计与md4和md5完全不同,那是因为md2是为8位机器做过设计优化的,而md4和md5却是面向32位的电脑。这三个算法的描述和c语言源代码在internet rfcs 1321中有详细的描述
C#加密算法代码
usingSystem; usingSystem.Collections.Generic; usingSystem.Text; usingSystem.Security.Cryptography; namespacemd5 { classProgram { staticvoidMain(string[]args) { Console.WriteLine(UserMd5("8")); Console.WriteLine(GetMd5Str("8")); } /**////<summary> ///MD516位加密 ///</summary> ///<paramnameparamname="ConvertString"></param> ///<returns></returns> publicstaticstringGetMd5Str(stringConvertString) { MD5CryptoServiceProvidermd5=newMD5CryptoServiceProvider(); stringt2=BitConverter.ToString(md5.ComputeHash(UTF8Encoding.Default.GetBytes(ConvertString)),4,8); t2t2=t2.Replace("-",""); returnt2; } http://www.cnblogs.com/sopper/archive/2007/01/08/615111.html /**////<summary> ///MD5 32位加密 ///</summary> ///<paramnameparamname="str"></param> ///<returns></returns> staticstringUserMd5(stringstr) { strstringcl=str; stringpwd=""; MD5MD5md5=MD5.Create();//实例化一个md5对像 //加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择 byte[]s=md5.ComputeHash(Encoding.UTF8.GetBytes(cl)); //通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得 for(inti=0;i<s.Length;i++) { //将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符 pwdpwd=pwd+s[i].ToString("X"); } returnpwd; } } }
关于C#中如何使用加密算法问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。