SHA1和md5的使用
来源:互联网 发布:网络运维面试题及答案 编辑:程序博客网 时间:2024/05/21 21:34
SHA1的全称是Secure Hash Algorithm(安全哈希算法)。加密哈希函数将任意长度的二进制字符串映射为固定长度的小型二进制字符串。加密哈希函数有这样一个属性:在计算上不大可能找到散列为相同的值的两个不同的输入;也就是说,两组数据的哈希值仅在对应的数据也匹配时才会匹配。数据的少量更改会在哈希值中产生不可预知的大量更改。所以你很难从加密后的文字中找到蛛丝马迹。
SHA1 算法的哈希值大小为 160 位。是一种不可逆的算法。
SHA1相关:
System.Security.Cryptography.SHA1
System.Security.Cryptography.SHA1CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1")
例子:
/// <summary>
/// 方法一:通过使用 new 运算符创建对象
/// <summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回16位加密结果,该结果取32位加密结果的第9位到25位</returns>
public string Get_SHA_Method1(string strSource)
{
//new
System.Security.Cryptography.SHA1 sha= new System.Security.Cryptography.SHA1CryptoServiceProvider();
//获取密文字节数组
byte [] bytResult = sha.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));
//转换成字符串,并取9到25位
//string strResult = BitConverter.ToString(bytResult, 4, 8);
//转换成字符串,32位
string strResult = BitConverter.ToString(bytResult);
//BitConverter转换出来的字符串会在每个字符中间产生一个分隔符,需要去除掉
strResult = strResult.Replace("-", "");
return strResult;
}
/// <summary>
/// 方法二:通过调用特定加密算法的抽象类上的 Create 方法,创建实现特定加密算法的对象。
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回32位加密结果</returns>
public string Get_SHA_Method2(string strSource)
{
string strResult = "";
//Create
System.Security.Cryptography.SHA1 sha = System.Security.Cryptography.SHA1.Create();
//注意编码UTF8、UTF7、Unicode等的选择
byte[] bytResult = sha.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));
//字节类型的数组转换为字符串
for (int i = 0; i < bytResult.Length; i++)
{
//16进制转换
strResult = strResult + bytResult[i].ToString("X");
}
return strResult;
}
/// <summary>
/// 方法三:直接使用HashPasswordForStoringInConfigFile生成
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回32位加密结果</returns>
public string Get_SHA_Method3(string strSource)
{
return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1");
}
posted @ 2008-03-24 22:11 天平水 阅读(87) | 评论 (0) | 编辑
MD5 算法的哈希值大小为 128 位。是一种不可逆的算法。
与MD5 相关:
System.Security.Cryptography.MD5
System.Security.Cryptography.MD5CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5")
例子:
/// <summary>
///方法一:通过使用 new 运算符创建对象
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回16位加密结果,该结果取32位加密结果的第9位到25位</returns>
public string Get_MD5_Method1(string strSource)
{
//new
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
//获取密文字节数组
byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));
//转换成字符串,并取9到25位
string strResult = BitConverter.ToString(bytResult, 4, 8);
//转换成字符串,32位
//string strResult = BitConverter.ToString(bytResult);
//BitConverter转换出来的字符串会在每个字符中间产生一个分隔符,需要去除掉
strResult = strResult.Replace("-", "");
return strResult;
}
///<summary>
///方法二:通过调用特定加密算法的抽象类上的Create 方法,创建实现特定加密算法的对象。
///</summary>
///<param name="strSource">需要加密的明文</param>
///<returns>返回位加密结果</returns>
public string Get_MD5_Method2(string strSource)
{
string strResult = "";
//Create
System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();
//注意编码UTF8、UTF7、Unicode等的选择
byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));
//字节类型的数组转换为字符串
for (int i = 0; i < bytResult.Length; i++)
{
//16进制转换
strResult = strResult + bytResult[i].ToString("X"); //只有对数字加密时会缺少位数
strResult = strResult + bytResult[i].ToString("X2"); //这样可以解决
strResult = strResult + bytResult[i].ToString("X").PadLeft(2,'0'); //这种方法也可以解决 PadLeft的意思是在字符串的左边添加空格,使字符串达到指定的长度。PadRight是在字符串的右侧加空格。
}
return strResult;
}
///<summary>
///方法三:直接使用HashPasswordForStoringInConfigFile生成
///</summary>
///<param name="strSource">需要加密的明文</param>
///<returns>返回位加密结果</returns>
public string Get_MD5_Method3(string strSource)
{
return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5");
}
*******************
ToString("X2");的意思
X 十六进制
2 每次都是两位数
比如 0x0A
如果没有2,就只会输出0xA
- SHA1和md5的使用
- MD5和SHA1算法的C++实现和使用
- MD5和SHA1算法的C++实现和使用
- ASP.NET中密码保护,MD5和SHA1算法的使用
- ASP.NET中密码保护,MD5和SHA1算法的使用
- ASP.NET中密码保护,MD5和SHA1算法的使用
- ASP.NET中密码保护,MD5和SHA1算法的使用
- ASP.NET中密码保护,MD5和SHA1算法的使用
- ASP.NET中密码保护,MD5和SHA1算法的使用
- 使用openssl就算文件的MD5和SHA1值
- python中的md5和sha1加密算法使用
- php使用MD5和SHA1进行加密
- Android计算文件的MD5和SHA1
- python的md5和sha1加密
- 获取RSA文件的MD5和SHA1
- python的md5和sha1加密
- python的md5和sha1加密
- python的md5和sha1加密
- 幻灯片形式设计:从方法到技巧
- 动词分类和ます形变化
- 匈牙利命名法
- direct acces to texture data
- HDMI通信之地址分配
- SHA1和md5的使用
- WinHEC上好玩的东西
- [C#] C#中调用父类的构造方法和成员
- import ext source
- 网站规划具体内容
- FORTRAN简介
- 强大的Excel
- 定时器简单应用
- に用法总结