下面的代码实现了一个可逆加密的方法。可以用于对Cookie,QueryString等加密处理。

查看例子
http://dotnet.aspx.cc/Exam/EncryptString.aspx
C#代码

EncryptString.aspx
<%@ Page language="c#" EnableViewState = "true" Codebehind="EncryptString.aspx.cs" AutoEventWireup="false" Inherits="eMeng.Exam.EncryptString" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<title>一个可逆加密的例子</title>
<meta name="GENERATOR" content="Microsoft Visual Studio.NET 7.0">
<meta name="CODE_LANGUAGE" content="Visual Basic 7.0">
<meta name="vs_defaultClientScript" content="JavaScript">
<meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
</HEAD>
<body>
<form id="Form1" method="post" runat="server">
<align="center">一个可逆加密的例子
<asp:TextBox id="TextBox1" runat="server" Width="96%">http://dotnet.aspx.cc/</asp:TextBox>
<asp:RadioButtonList id="RadioButtonList1" runat="server" Font-Bold="True" RepeatDirection="Horizontal"
AutoPostBack
="True"></asp:RadioButtonList>
<asp:TextBox id="TextBox2" runat="server" Width="96%"></asp:TextBox>
<asp:TextBox id="Textbox3" runat="server" Width="96%"></asp:TextBox>
</p>
</form>
</body>
</HTML>

EncryptString.aspx.cs
using System;
using System.Collections;
using System.ComponentModel;
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.IO;
using System.Text;
using System.Security.Cryptography;


namespace eMeng.Exam
{
    
/// <summary>
    
/// EncryptString 的摘要说明。
    
/// </summary>

    public class EncryptString : System.Web.UI.Page
    
{
        
protected System.Web.UI.WebControls.TextBox TextBox1;
        
protected System.Web.UI.WebControls.RadioButtonList RadioButtonList1;
        
protected System.Web.UI.WebControls.TextBox TextBox2;
        
protected System.Web.UI.WebControls.TextBox Textbox3;
        
protected System.Web.UI.HtmlControls.HtmlForm Form1;

        
private void Page_Load(object sender, System.EventArgs e)
        
{
            
// 在此处放置用户代码以初始化页面
            if (!this.IsPostBack)
            
{
                ArrayList MyList 
= new ArrayList();
                MyList.Add(
"加密");
                MyList.Add(
"解密");
                RadioButtonList1.DataSource 
= MyList;
                RadioButtonList1.DataBind();
            }

        }


        
Web 窗体设计器生成的代码

        
private void RadioButtonList1_SelectedIndexChanged(object sender, System.EventArgs e)
        
{
            
if (RadioButtonList1.SelectedIndex == 0)
                TextBox2.Text 
= EncryptText(TextBox1.Text);
            
else
                Textbox3.Text 
= DecryptText(TextBox2.Text);
        }

        
// 加密
        public string EncryptText(String strText)
        
{
            
return Encrypt(strText, "&%#@?,:*");
        }


        
//'解密
        public String DecryptText(String strText)
        
{
            
return Decrypt(strText, "&%#@?,:*");
        }

        
//'加密函数
        private String Encrypt(String strText, String strEncrKey)
        
{
            Byte[] byKey 
= { };
            Byte[] IV 
= 0x120x340x560x780x900xAB0xCD0xEF };
            
try
            
{
                byKey 
= System.Text.Encoding.UTF8.GetBytes(strEncrKey.Substring(08));
                DESCryptoServiceProvider des 
= new DESCryptoServiceProvider();
                Byte[] inputByteArray 
= Encoding.UTF8.GetBytes(strText);
                MemoryStream ms 
= new MemoryStream();
                CryptoStream cs 
= new CryptoStream(ms, des.CreateEncryptor(byKey, IV), CryptoStreamMode.Write);
                cs.Write(inputByteArray, 
0, inputByteArray.Length);
                cs.FlushFinalBlock();
                
return Convert.ToBase64String(ms.ToArray());
            }

            
catch (Exception ex)
            
{
                
return ex.Message;
            }

        }


        
//'解密函数
        private String Decrypt(String strText, String sDecrKey)
        
{
            Byte[] byKey 
= { };
            Byte[] IV 
= 0x120x340x560x780x900xAB0xCD0xEF };
            Byte[] inputByteArray 
= new byte[strText.Length];
            
try
            
{
                byKey 
= System.Text.Encoding.UTF8.GetBytes(sDecrKey.Substring(08));
                DESCryptoServiceProvider des 
= new DESCryptoServiceProvider();
                inputByteArray 
= Convert.FromBase64String(strText);
                MemoryStream ms 
= new MemoryStream();
                CryptoStream cs 
= new CryptoStream(ms, des.CreateDecryptor(byKey, IV), CryptoStreamMode.Write);
                cs.Write(inputByteArray, 
0, inputByteArray.Length);
                cs.FlushFinalBlock();
                System.Text.Encoding encoding 
= System.Text.Encoding.UTF8;
                
return encoding.GetString(ms.ToArray());
            }

            
catch (Exception ex)
            
{
                
return ex.Message;
            }

        }

    }

}


VB.NET代码

<%@ Page Language="vb" AutoEventWireup="false" Codebehind="EncString.aspx.vb"
 Inherits
="aspxWeb.EncString" 
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
  
<HEAD>
    
<title>一个可逆加密的例子</title>
    
<meta name="GENERATOR" content="Microsoft Visual Studio.NET 7.0">
    
<meta name="CODE_LANGUAGE" content="Visual Basic 7.0">
    
<meta name="vs_defaultClientScript" content="JavaScript">
    
<meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
  
</HEAD>
  
<body MS_POSITIONING="GridLayout">
    
<asp:Label id="Label1" runat="server"></asp:Label>
    
<align="center">
      
<form id="Form1" method="post" runat="server">
        
<FONT face="宋体">
          
<asp:TextBox id="TextBox1" runat="server" Width="96%"></asp:TextBox>
          
<asp:RadioButtonList id="RadioButtonList1" runat="server" Font-Bold="True"
           RepeatDirection
="Horizontal" AutoPostBack="True" OnSelectedIndexChanged="ShowRes">
           
</asp:RadioButtonList>
          
<asp:TextBox id="TextBox2" runat="server" Width="96%"></asp:TextBox>
        
</FONT>
      
</form>
    
</p>
  
</body>
</HTML>


后端代码EncString.aspx.vb:

Imports System
Imports System.IO
Imports System.Xml
Imports System.Text
Imports System.Security.Cryptography
Public Class EncString
  
Inherits System.Web.UI.Page
  
Protected WithEvents TextBox1 As System.Web.UI.WebControls.TextBox
  
Protected WithEvents TextBox2 As System.Web.UI.WebControls.TextBox
  
Protected WithEvents Form1 As System.Web.UI.HtmlControls.HtmlForm
  
Protected WithEvents Label1 As System.Web.UI.WebControls.Label
  
Protected WithEvents RadioButtonList1 As System.Web.UI.WebControls.RadioButtonList

Web Form Designer Generated Code

  
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 

MyBase.Load
    
'Put user code to initialize the page here
    Label1.Text = "<h3 align='center'>一个可逆加密的例子</h3>"
    
If Not IsPostBack Then
      
Dim MyList As New ArrayList()
      MyList.Add(
"加密")
      MyList.Add(
"解密")
      RadioButtonList1.DataSource 
= MyList
      RadioButtonList1.DataBind()
    
End If
  
End Sub


  
' 加密
  Public Shared Function EncryptText(ByVal strText As StringAs String
    
Return Encrypt(strText, "&%#@?,:*")
  
End Function


  
'解密
  Public Shared Function DecryptText(ByVal strText As StringAs String
    
Return Decrypt(strText, "&%#@?,:*")
  
End Function


  
'加密函数
  Private Shared Function Encrypt(ByVal strText As StringByVal strEncrKey As StringAs String
    
Dim byKey() As Byte = {}
    
Dim IV() As Byte = {&H12, &H34, &H56, &H78, &H90, &HAB, &HCD, &HEF}
    
Try
      byKey 
= System.Text.Encoding.UTF8.GetBytes(Left(strEncrKey, 8))
      
Dim des As New DESCryptoServiceProvider()
      
Dim inputByteArray() As Byte = Encoding.UTF8.GetBytes(strText)
      
Dim ms As New MemoryStream()
      
Dim cs As New CryptoStream(ms, des.CreateEncryptor(byKey, IV), CryptoStreamMode.Write)
      cs.Write(inputByteArray, 
0, inputByteArray.Length)
      cs.FlushFinalBlock()
      
Return Convert.ToBase64String(ms.ToArray())
    
Catch ex As Exception
      
Return ex.Message
    
End Try
  
End Function


  
'解密函数
  Private Shared Function Decrypt(ByVal strText As StringByVal sDecrKey As StringAs String
    
Dim byKey() As Byte = {}
    
Dim IV() As Byte = {&H12, &H34, &H56, &H78, &H90, &HAB, &HCD, &HEF}
    
Dim inputByteArray(strText.Length) As Byte
    
Try
      byKey 
= System.Text.Encoding.UTF8.GetBytes(Left(sDecrKey, 8))
      
Dim des As New DESCryptoServiceProvider()
      inputByteArray 
= Convert.FromBase64String(strText)
      
Dim ms As New MemoryStream()
      
Dim cs As New CryptoStream(ms, des.CreateDecryptor(byKey, IV), CryptoStreamMode.Write)
      cs.Write(inputByteArray, 
0, inputByteArray.Length)
      cs.FlushFinalBlock()
      
Dim encoding As System.Text.Encoding = System.Text.Encoding.UTF8
      
Return encoding.GetString(ms.ToArray())
    
Catch ex As Exception
      
Return ex.Message
    
End Try
  
End Function


  
Public Sub ShowRes(ByVal sender As ObjectByVal e As System.EventArgs)_
   
Handles RadioButtonList1.SelectedIndexChanged
    
If RadioButtonList1.SelectedIndex = 0 Then
      TextBox2.Text 
= EncryptText(TextBox1.Text)
    
Else
      TextBox2.Text 
= DecryptText(TextBox1.Text)
    
End If
  
End Sub

End Class

http://www.chenjiliang.com/Article/View.aspx?ArticleID=1165&TypeID=5
posted on 2007-01-29 11:16  mbskys  阅读(213)  评论(0)    收藏  举报