Asp.Net 加密示例_[Asp.Net教程]
SHA1算法的散列值大小为160位。一般的加密方式为
byte[] data=System.Text.Encoding.Unicode.GetBytes(source.ToCharArray());
System.Security.Cryptography.SHA1 sha=new System.Security.Cryptography.SHA1CryptoServiceProvider();
byte[] result=sha.ComputeHash(data);
使用SHA1对密码实现加密,需要使用以下的方法:
string EnPswdStr=System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(source, "MD5");
或许有的人会问,既然都是采用SHA1方法加密,为什么对密码的加密就不能使用原方法呢?因为一般情况下SHA1方法加密出来的密码并不是常规字符,有些字符甚至无法显示出来,如果使用这样的字符作为密码,在存入数据库时有些字符会被处理掉,这样加密结果就会失真,在进行密码验证时就会出现无法预料的差错。而采用密码加密函数的话就避免了这一个问题,它加密出来的结果都是常规字符,在数据库进行存储和程序处理时不会失真。
下面是例子程序:
Default.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
无标题页 Default.aspx.cs
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (IsPostBack)
{
//获取要加密的字段,并转化为byte[]数组
byte[] data = System.Text.Encoding.Unicode.GetBytes(TextBox1.Text.ToCharArray());
//建立加密服务
System.Security.Cryptography.SHA1 sha = new System.Security.Cryptography.SHA1CryptoServiceProvider();
//加密byte[]数组
byte[] result = sha.ComputeHash(data);
//将加密后的数组转化为字符串
string sResult = System.Text.Encoding.Unicode.GetString(result);
//显示出来
Label1.Text = "SHA1普通加密:" + sResult.ToString() + "
";
//作为密码方式加密
string EnPswdStr = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(TextBox1.Text.ToString(), "MD5");
//显示出来
Label2.Text = "SHA1密码加密:" + EnPswdStr + "
";
}
}
}
运行效果图:

输入22然后点加密:

来源:xingyao的blog