C#中简单调用MD5方法以及MD5简介
来源:互联网 发布:fkshow软件安卓版 编辑:程序博客网 时间:2024/06/05 02:03
MD5简介:
MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc发明,经MD2、MD3和MD4发展而来。MD5将任意长度的“字节串”变换成一个128bit的大整数,并且它是一个不可逆的字符串变换算法。换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字符串有无穷多个,这有点象不存在反函数的数学函数。
MD5算法:
第一步:增加填充
增加padding使得数据长度(bit为单位)模512为448。如果数据长度正好是模512为448,增加512个填充bit,也就是说填充的个数为1-512。第一个bit为1,其余全部为0。
第二步:补足长度
将数据长度转换为64bit的数值,如果长度超过64bit所能表示的数据长度的范围,值保留最后64bit,增加到前面填充的数据后面,使得最后的数据为512bit的整数倍。也就是32bit的16倍的整数倍。在RFC1321中,32bit称为一个word。
第三步:初始化变量:
用到4个变量,分别为A、B、C、D,均为32bit长。初始化为:
A: 01 23 45 67
B: 89 ab cd ef
C: fe dc ba 98
D: 76 54 32 10
第四步:数据处理:
首先定义4个辅助函数:
F(X,Y,Z) = XY v not(X) Z
G(X,Y,Z) = XZ v Y not(Z)
H(X,Y,Z) = X xor Y xor Z
I(X,Y,Z) = Y xor (X v not(Z))
其中:XY表示按位与,X v Y表示按位或,not(X)表示按位取反。xor表示按位异或。
函数中的X、Y、Z均为32bit。定义一个需要用到的数组:T(i),i取值1-64,T(i)等于abs(sin(i))的4294967296倍的整数部分,i为弧度。
假设前三步处理后的数据长度为32*16*Nbit
第五步:输出:
最后得到的ABCD为输出结果,共128bit。A为低位,D为高位。
MD5在ASP.net(C#)中的实现:
MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc发明,经MD2、MD3和MD4发展而来。MD5将任意长度的“字节串”变换成一个128bit的大整数,并且它是一个不可逆的字符串变换算法。换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字符串有无穷多个,这有点象不存在反函数的数学函数。
MD5算法:
第一步:增加填充
增加padding使得数据长度(bit为单位)模512为448。如果数据长度正好是模512为448,增加512个填充bit,也就是说填充的个数为1-512。第一个bit为1,其余全部为0。
第二步:补足长度
将数据长度转换为64bit的数值,如果长度超过64bit所能表示的数据长度的范围,值保留最后64bit,增加到前面填充的数据后面,使得最后的数据为512bit的整数倍。也就是32bit的16倍的整数倍。在RFC1321中,32bit称为一个word。
第三步:初始化变量:
用到4个变量,分别为A、B、C、D,均为32bit长。初始化为:
A: 01 23 45 67
B: 89 ab cd ef
C: fe dc ba 98
D: 76 54 32 10
第四步:数据处理:
首先定义4个辅助函数:
F(X,Y,Z) = XY v not(X) Z
G(X,Y,Z) = XZ v Y not(Z)
H(X,Y,Z) = X xor Y xor Z
I(X,Y,Z) = Y xor (X v not(Z))
其中:XY表示按位与,X v Y表示按位或,not(X)表示按位取反。xor表示按位异或。
函数中的X、Y、Z均为32bit。定义一个需要用到的数组:T(i),i取值1-64,T(i)等于abs(sin(i))的4294967296倍的整数部分,i为弧度。
假设前三步处理后的数据长度为32*16*Nbit
第五步:输出:
最后得到的ABCD为输出结果,共128bit。A为低位,D为高位。
MD5在ASP.net(C#)中的实现:
- //欲进行md5加密的字符串
- string test = "123abc";
- //获取加密服务
- System.Security.Cryptography.MD5CryptoServiceProvider md5CSP = new System.Security.Cryptography.MD5CryptoServiceProvider();
- //获取要加密的字段,并转化为Byte[]数组
- byte[] testEncrypt = System.Text.Encoding.Unicode.GetBytes(test);
- //加密Byte[]数组
- byte[] resultEncrypt = md5CSP.ComputeHash(testEncrypt);
- //将加密后的数组转化为字段(普通加密)
- string testResult = System.Text.Encoding.Unicode.GetString(resultEncrypt);
- //作为密码方式加密
- string Encrypt PWD = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(test, "MD5");
只需最后一段语句即可进行MD5加密,无需引入任何包.
C#
MD5CryptoServiceProvider MD5 = new MD5CryptoServiceProvider();
byte[] bys = Encoding.Unicode.GetBytes(textBox1.Text);
byte[] getbys = MD5.ComputeHash(bys);
string str = Encoding.Unicode.GetString(getbys);
str = BitConverter.ToString(getbys);
richTextBox1.Text = str;
0 0
- C#中简单调用MD5方法以及MD5简介
- C#调用md5方法
- C#调用MD5算法就是这么简单!
- C#调用MD5
- C#调用MD5算法
- C#中使用MD5非常简单
- LoadRunner调用md5方法
- C#中使用MD5加密的方法
- C#中使用MD5加密的方法
- C#中使用MD5加密的方法
- MD5加密简介以及C#下的操作实现
- C# MD5 加密方法
- C# md5加密方法
- 简单MD5加密方法
- C#中 MD5加密
- C#中 MD5加密
- C#中MD5加密
- C# 简单使用 MD5 加密
- 第15周项目 3.1 OJ
- word转换成字符串
- HTTP Error 503. The service is unavailable
- 在mybatis字段对应不上出现的小错误
- Xmanager 图形界面配置
- C#中简单调用MD5方法以及MD5简介
- SharedPreferences用法
- struts2中如何自动加载xml文件(不用修改配置文件)
- 深入理解java 虚拟机类文件结构
- nginx 服务器系统优化
- Android 学习笔记2 MENU
- C#配置app.config
- UVA刷题一周
- JQuery插件iScroll实现下拉刷新,滚动翻页特效