读书人

一个MD5加密的有关问题

发布时间: 2012-01-01 23:10:55 作者: rapoo

一个MD5加密的问题
MD5加密后怎么解密啊?
比如用户注册,密码是用MD5加密的,下次此用户登录的时候怎么比较密码是否一致呢?
我用的是。NET自带的类写的加密,代码如下:
string MD5str = FormsAuthentication.HashPasswordForStoringInConfigFile(TextBox2.Text, "MD5 ");
SqlConnection conn = new SqlConnection( "server=.;uid=sa;database=pubs ");
SqlCommand com = new SqlCommand( "insert into userLogin(uname,upwd) values( ' "+TextBox1.Text+ " ', ' "+MD5str+ " ') ",conn);
conn.Open();
com.ExecuteNonQuery();
conn.Close();

[解决办法]
MD5是不能逆向运算的
你把用户输入的密码也进行MD5加密
再和数据库中的进行比较
[解决办法]
登陆时,把登陆密码加密后到数据库中去比较
[解决办法]
MD5是不可逆的.
将密码MD5后保存在DB.
当用户登陆时, 将用户提交的密码MD5后与DB的密码对比, 一样的话就表示用户提交正确!
就这么简单.
[解决办法]
给你转贴一个

using System.IO;

using System.Text;


//方法

//加密方法

public string Encrypt(string pToEncrypt, string sKey)

{

DESCryptoServiceProvider des = new DESCryptoServiceProvider();

//把字符串放到byte数组中

//原来使用的UTF8编码,我改成Unicode编码了,不行

byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);

//byte[] inputByteArray=Encoding.Unicode.GetBytes(pToEncrypt);


//建立加密对象的密钥和偏移量

//原文使用ASCIIEncoding.ASCII方法的GetBytes方法

//使得输入密码必须输入英文文本

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);

//Write the byte array into the crypto stream

//(It will end up in the memory stream)

cs.Write(inputByteArray, 0, inputByteArray.Length);

cs.FlushFinalBlock();

//Get the data back from the memory stream, and into a string

StringBuilder ret = new StringBuilder();

foreach(byte b in ms.ToArray())

{

//Format as hex

ret.AppendFormat( "{0:X2} ", b);

}

ret.ToString();

return ret.ToString();

}


//解密方法

public string Decrypt(string pToDecrypt, string sKey)

{

DESCryptoServiceProvider des = new DESCryptoServiceProvider();


//Put the input string into the byte array

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);

//Flush the data through the crypto stream into the memory stream

cs.Write(inputByteArray, 0, inputByteArray.Length);

cs.FlushFinalBlock();


//Get the decrypted data back from the memory stream

//建立StringBuild对象,CreateDecrypt使用的是流对象,必须把解密后的文本变成流对象

StringBuilder ret = new StringBuilder();



return System.Text.Encoding.Default.GetString(ms.ToArray());

}


备注:

1. sKey输入密码的时候,必须使用英文字符,区分大小写,且字符数量是8个,不能多也不能少,否则出错。

读书人网 >asp.net

热点推荐