C# MD5算法加密解密

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Security.Cryptography;
using System.IO;

namespace MD5Demo
{
    class Program
    {
        static void Main(string[] args)
        {
            string myKey = GenerateKey();
            Console.WriteLine("{0}", MD5Encrypt("hello", myKey));
            Console.WriteLine("{0}", MD5Decrypt(MD5Encrypt("hello", myKey),myKey));
            Console.ReadKey();
        }
        //创建密钥
        public static string GenerateKey()
        {
            DESCryptoServiceProvider desCrypto = (DESCryptoServiceProvider)DESCryptoServiceProvider.Create();
            return ASCIIEncoding.ASCII.GetString(desCrypto.Key);
        }

        ///MD5加密
        public static string MD5Encrypt(string pToEncrypt,string sKey)
        {
             DESCryptoServiceProvider des = new DESCryptoServiceProvider();
             byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);
             des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
             des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
             MemoryStream ms = new MemoryStream();
             CryptoStream cs = new CryptoStream(ms,des.CreateEncryptor(),CryptoStreamMode.Write);
             cs.Write(inputByteArray,0,inputByteArray.Length);
             cs.FlushFinalBlock();
             StringBuilder ret = new StringBuilder();
             foreach(byte b in ms.ToArray())
             {
                ret.AppendFormat("{0:X2}",b);
             }
             ret.ToString();
             return ret.ToString();
        }

        ///MD5解密
        public static string MD5Decrypt(string pToDecrypt, string sKey)
        {
             DESCryptoServiceProvider des = new DESCryptoServiceProvider();
             byte[] inputByteArray = new byte[pToDecrypt.Length / 2];
             for(int x = 0;x < pToDecrypt.Length / 2;x++)
             {
                  int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2,2),16));
                  inputByteArray[x] = (byte)i;
             }

             des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
             des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
             MemoryStream ms = new MemoryStream();
             CryptoStream cs = new CryptoStream(ms,des.CreateDecryptor(),CryptoStreamMode.Write);
             cs.Write(inputByteArray,0,inputByteArray.Length);
             cs.FlushFinalBlock();
             StringBuilder ret = new StringBuilder();  
             return System.Text.Encoding.Default.GetString(ms.ToArray());
        }

    }
}

posted @ 2009-10-21 04:51  錯咗  阅读(5554)  评论(0编辑  收藏  举报