MD5:属于一种加密算法,单向不可逆加密。
1 对用户密码或者一些隐私的信息进行加密处理
2 对一段文字生产成信息摘要,这个摘要是具有唯一性的,可以作为数字的签名。
3 用于验证文件的有效性
4 在哈希函数计算散列值
先看看加密的基本概念:
"加密",是一种限制对网络上传输数据的访问权的技术。原始数据(也称为明文,plaintext)被加密设备(硬件或软件)和密钥加密而产生的经过编码的数据称为密文(ciphertext)。将密文还原为原始明文的过程称为解密,它是加密的反向处理,但解密者必须利用相同类型的加密设备和密钥对密文进行解密。
Base64加密方式:网络上最常见的用于传输8Bit字节码的编码方式之一,是一种基于64个可打印字符来表示二进制数据的方法。从二进制到字符的过程,base64是可逆的
关于MD5编码的实例:
一:封装一个方法紧接着在窗体界面进行调用
cs
public static string MD5Test(string i1)
{
// 1 创建MD5对象 c#提供了Cryptography类库中md5类生产md5对象
// Security 安全
MD5 md5 = System.Security.Cryptography.MD5.Create();
// 2 使用md5对象对i1进行加密处理 编码之后的字节数组。
byte[] bs = System.Text.Encoding.ASCII.GetBytes(i1);
// 3 把字节数组通过md5进行加密ComputeHash
// Compute 计算
// Hash 哈希函数
// y = x +1 x=0
byte[] hashS = md5.ComputeHash(bs);
//4 把数组转成字符串
StringBuilder s = new StringBuilder();//可变字符串
for (int i = 0; i < hashS.Length; i++)
{ //16进制0-15 ,0-9还是数字,
//ToString("X2")
//X代表是16进制,大写的X是代表大写16进制的
//小写的x代表的小写的16进制
//2 不足俩位的前面补0
//例如0x0A,如果没有2. 输出结果是0xA
s.Append(hashS[i].ToString("X2")); //追加字符串 ,等同于+拼接字符串
}
return s.ToString();
}
二: 创建一个Form窗体 里面定义输入框及按钮
定义按钮的方法
private void button1_Click(object sender, EventArgs e)
{
this.label1.Text = string.Empty;
this.label1.Text = MyMD5.MD5Test(textBox1.Text);
}
三 运行结果如下