转载 ASP.NET中密码保护,MD5和SHA1算法的使用收藏

新一篇: 几个笑话 | 旧一篇: 编程太久了,心情也越烦躁,会不会因此而失去了很多。。。? 同感的必看,潜藏人生的哲理

ASP.NET中密码保护,MD5和SHA1算法的使用



你的主页或者你管理的网站有各种密码需要保护,把密码直接放在数据库或者文件中存在不少安全隐患,所以密码加密后存储是最常见的做法。在ASP.NET中实现加密非常容易。.NET SDK中提供了CookieAuthentication类,其中的HashPasswordForStoringInConfigFile方法可直接使用MD5和SHA1算法。例子如下:
file: encrypting.aspx
<%@ Page language="c#" Codebehind="encrypting.cs" AutoEventWireup="false" Inherits="encrypting.encrypting" %>
<html><head>
    <meta name="GENERATOR" Content="Microsoft Visual Studio 7.0">
    <meta name="CODE_LANGUAGE" Content="C#"></head>
  <body>

    <form method="post" runat="server">
<p>&nbsp;</p>
<p>
<asp:TextBox id=TextBox1 runat="server"></asp:TextBox>
<asp:Button id=Button1 runat="server" Text="encrypting"></asp:Button></p>
<p>Encrypting Password(MD5):
<asp:Label id=MD5 runat="server"></asp:Label></p>
     </form>

  </body></html>

file:encrypting.cs

namespace encrypting
{
    using System;
    using System.Collections;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Web;
    using System.Web.SessionState;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.HtmlControls;
    using System.Web.Security;
    /// <summary>
    ///    Summary description for encrypting.
    /// </summary>
    public class encrypting : System.Web.UI.Page
    {
  protected System.Web.UI.WebControls.Label MD5;
  protected System.Web.UI.WebControls.Button Button1;
  protected System.Web.UI.WebControls.TextBox TextBox1;

public encrypting()
{
     Page.Init += new System.EventHandler(Page_Init);
        }
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                //
                // Evals true first time browser hits the page
                //
            }
        }
        protected void Page_Init(object sender, EventArgs e)
        {
            //
            // CODEGEN: This call is required by the ASP+ Windows Form Designer.
            //
            InitializeComponent();
        }
        /// <summary>
        ///    Required method for Designer support - do not modify
        ///    the contents of this method with the code editor.
        /// </summary>
        private void InitializeComponent()
  {
   Button1.Click += new System.EventHandler (this.Button1_Click);
   this.Load += new System.EventHandler (this.Page_Load);
  }
  public void Button1_Click (object sender, System.EventArgs e)
  {
   MD5.Text = CookieAuthentication.HashPasswordForStoringInConfigFile(TextBox1.Text,"MD5");
   //SHA1 use CookieAuthentication.HashPasswordForStoringInConfigFile(TextBox1.Text,"SHA1");
  }
    }
}
注意:类CookieAuthentication的namespace是System.Web.Security。  


 

发表于 @ 2006年12月30日 11:01:00|评论(loading...)|编辑

新一篇: 几个笑话 | 旧一篇: 编程太久了,心情也越烦躁,会不会因此而失去了很多。。。? 同感的必看,潜藏人生的哲理

评论

#dzj_110 发表于2006-12-31 09:48:44  IP: 221.221.152.*
我在vs2003中发现在System.Web.Security下面没有CookieAuthentication类。我该怎么办?
#dzj_110 发表于2006-12-31 10:06:12  IP: 221.221.152.*
我是初学者,刚发现System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(,)可以实现,不好意思。
#zjysky 发表于2007-01-05 17:00:47  IP:
那怎么解密阿,只是把明文加密存储了阿,如果读取的时候怎么用阿
zjypp@126.com
发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © charisma(蚂蚁)