文本加密

来源:互联网 发布:阿里云大厦 编辑:程序博客网 时间:2024/06/05 08:42

<%@ Page Language="C#" ContentType="text/html"%>
<%@ Import Namespace="System"%>
<script language="C#" runat="server">
void Page_Load(Object sender,EventArgs e){
//获取要加密的字段,并转化为Byte[]数组
byte[] data=System.Text.Encoding.Unicode
.GetBytes(source.Text.ToCharArray());
//建立加密服务
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
//加密Byte[]数组
byte[] result= md5.ComputeHash(data);
//将加密后的数组转化为字段
string sResult=System.Text.Encoding.Unicode.GetString(result);
//显示出来
sha1_1.Text="MD5普通加密:"+sResult.ToString()+"<br/>";
//作为密码方式加密
string EnPswdStr=System.Web.Security.FormsAuthentication.
HashPasswordForStoringInConfigFile(source.Text.ToString(),"MD5");
//显示出来
sha1_2.Text="MD5密码加密:"+EnPswdStr+"<br/>";
}
</script>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>测试</title>
</head>
<body>
<h3>SHA1加密</h3>
<form id="Form1" runat="server">
<asp:label id="sha1_1" runat="server"></asp:label>
<asp:label id="sha1_2" runat="server"></asp:label>
<asp:textbox ID="source" runat="server" TextMode="SingleLine" Text="test" AutoPostBack="true" />
(回车)
</form>
</body>
</html>

 

 

 


=========================================================

[asp.net安全].net MD5和SHA1加密大全
互联力量软件   2011年03月14日 2:00   评论?  
      .NET MD5和SHA1加密方法有哪些呢?首先我们来看看什么是MD5?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位的信息摘要。

加密哈希函数将任意长度的二进制字符串映射为固定长度的小型二进制字符串。加密哈希函数有这样一个属性:在计算上不大可能找到散列为相同的值的两个不同的输入;也就是说,两组数据的哈希值仅在对应的数据也匹配时才会匹配。数据的少量更改会在哈希值中产生不可预知的大量更改。所以你很难从加密后的文字中找到蛛丝马迹。

ASP.NET SHA1加密中的SHA1是什么呢?SHA1的全称是Secure Hash Algorithm(安全哈希算法)

MD5 算法的哈希值大小为 128 位。而SHA1 算法的哈希值大小为 160 位。两种算法都是不可逆。

虽说2004年8月17日的美国加州圣巴巴拉的国际密码学会议(Crypto’2004)上,来自中国山东大学的王小云教授做了破译MD5、HAVAL-128、 MD4和RIPEMD算法的报告,公布了MD系列算法的破解结果。宣告了固若金汤的世界通行密码标准MD5的堡垒轰然倒塌,引发了密码学界的轩然大波。但是我觉得对于我们做普通的软件来说,这个加密安全程度已经足够使用了。

ASP.NET MD5和SHA1加密方法的概念介绍过了,现在来看看具体的类有哪些呢?

我们平常用的最多的无非就是加密用户密码,把加密好的密码存储到数据库中,进行密码比较的时候,把用户输入的密码再进行加密,然后与数据库中的密文进行比较。至于asp.net类中是如何实现加密算法的,这个我们不需要关心,会用就行了。

C#生成MD5校验码 
      最近在写一个小程序,需要为一个文件生成MD5校验码来对比不同的文件版本,然后做操作。
      要在C#中使用MD5,要先引入命名空间System.Security.Cryptography
      下面就是生成校验码的具体方法
      string f = "C://txt.txt";
      MD5 md5 = MD5.Create();
      StringBuilder sb = new StringBuilder();

      using (FileStream fs = File.Open(f, FileMode.Open))
     {
          foreach (byte b in md5.ComputeHash(fs))
               sb.Append(b.ToString("x2").ToLower());
     }

     Console.WriteLine("MD5校验码: {0}", sb.ToString());

C# 计算文件的MD5值
    MD5 是 Message Digest Algorithm 5(信息摘要算法)的缩写,MD5 一种散列(Hash)技术,广泛用于加密、解密、数据签名和数据完整性校验等方面。任何一个文件,无论是可执行程序、图像文件、临时文件或者其他任何类型的文件,也不管它体积多大,都可以计算出一个MD5值,如果文件被修改过,就算只改动了一个字节,其 MD5 值也会变得完全不同。因此,我们可以通过对比同一文件的 MD5 值,来校验这个文件是否被“篡改”过。

C# 可以方便的计算出文件的 MD5 值: 计算文件的MD5值
/// <summary>
/// 计算文件的 MD5 值
/// </summary>
/// <param name="fileName">要计算 MD5 值的文件名和路径</param>
/// <returns>MD5 值16进制字符串</returns>
public static string MD5File(string fileName)
{
    return HashFile(fileName, "md5");
}

 

/// <summary>
/// 计算文件的哈希值
/// </summary>
/// <param name="fileName">要计算哈希值的文件名和路径</param>
/// <param name="algName">算法:sha1,md5</param>
/// <returns>哈希值16进制字符串</returns>
public static string HashFile(string fileName, string algName)
{
    if (!System.IO.File.Exists(fileName))
        return string.Empty;

    FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
    byte[] hashBytes = HashData(fs, algName);
    fs.Close();
    return ByteArrayToHexString(hashBytes);
}

 

/// <summary>
/// 计算哈希值
/// </summary>
/// <param name="stream">要计算哈希值的 Stream</param>
/// <param name="algName">算法:sha1,md5</param>
/// <returns>哈希值字节数组</returns>
public static byte[] HashData(Stream stream, string algName)
{
    HashAlgorithm algorithm;
    if (algName == null)
    {
        throw new ArgumentNullException("algName 不能为 null");
    }
    if (string.Compare(algName, "sha1", true) == 0)
    {
        algorithm = SHA1.Create();
    }
    else
    {
        if (string.Compare(algName, "md5", true) != 0)
        {
            throw new Exception("algName 只能使用 sha1 或 md5");
        }
        algorithm = MD5.Create();
    }
    return algorithm.ComputeHash(stream);
}
    ComputeHash 方法返回的是哈希值字节数组,而文件的 MD5 值通常是用16进制的字符串表示,字节数组转换为16进制表示的字符串的方法在 System.Web.Configuration.MachineKeySection 中已经提供了一个名为 ByteArrayToHexString 方法,但是该方法是 NonPublic 的,我们不能直接调用。这里我们通过反射来调用 MachineKeySection 中的 ByteArrayToHexString 方法。

通过反射调用 MachineKeySection 中的 ByteArrayToHexString 方法: 通过反射调用 MachineKeySection 中的 ByteArrayToHexString 方法

/// <summary>
/// 字节数组转换为16进制表示的字符串
/// </summary>
public static string ByteArrayToHexString(byte[] buf)
{
    int iLen = 0;

    // 通过反射获取 MachineKeySection 中的 ByteArrayToHexString 方法,该方法用于将字节数组转换为16进制表示的字符串。
    Type type = typeof(System.Web.Configuration.MachineKeySection);
    MethodInfo byteArrayToHexString = type.GetMethod("ByteArrayToHexString", BindingFlags.Static | BindingFlags.NonPublic);

    // 字节数组转换为16进制表示的字符串
    return (string)byteArrayToHexString.Invoke(null, new object[] { buf, iLen });
}
    如今“MD5碰撞生成器”的出现,使 MD5 也正在面临挑战。

 

原创粉丝点击