使用MD5將字串加密 C# VS2005 Sample Code

  MD5的加密已經出來很長一段時間了,也不是什麼特別的新技術,寫這篇的用意也有點像是給自己的一個Note,畢竟加密的功能不常用,最多寫成一個Class,未來去呼叫就好,怕自己也會忘記,所以把這個寫下來.

  初步的UI設定如下:

H執行是單純加密,而Salt執行則是跑Salted Hash的動作.

單純加密比較不好,如果被人猜到加密方法是採MD5,也沒有Salted,那會風險會高一點,而Salt的效果,因為多了一個Value去加密,除了前面的都要猜到外,還要知道Salted Value才可以.而Salted Value就看大家要怎麼去設了,這裡也只是單純的Demo.

單純加密的部份,其實很簡單,程式碼如下 :

byte[] Original = Encoding.Default.GetBytes(txt_Source.Text); //將字串來源轉為Byte[]
MD5 s1 = MD5.Create(); //使用MD5
byte[] Change = s1.ComputeHash(Original); //進行加密
txt_Result.Text = Convert.ToBase64String(Change); //將加密後的字串從byte[]轉回string

很簡短的四行,就可以達成了,但個人還是喜歡用Salted,畢竟要加密,就要降低風險.而這方法加密後的結果如下 :

值 : 123456789

結果 : JfnnlDI7RTiF9RgfG2JNCw==

Salted Hash就比較複雜了一點 :

string salted = txt_Salt.Text.Trim(); //宣告變數,儲存Salted值
if (salted.Length == 0) //如果使用者沒給Salt值,那給預設
{
    salted = "t15t";
}

byte[] Original = Encoding.Default.GetBytes(txt_Source.Text); //將來源字串轉為byte[]
byte[] SaltValue = Encoding.Default.GetBytes(salted); //將Salted Value轉為byte[]
byte[] ToSalt = new byte[Original.Length + SaltValue.Length]; //宣告新的byte[]來儲存加密後的值
Original.CopyTo(ToSalt, 0); //將來源字串複製到新byte[]
SaltValue.CopyTo(ToSalt, Original.Length); //將Salted Value複製到新byte[]
MD5 st = MD5.Create(); //使用MD5
byte[] SaltPWD = st.ComputeHash(ToSalt); //進行加密
byte[] PWD = new byte[SaltPWD.Length + SaltValue.Length]; //宣告新byte[]儲存加密及Salted的值
SaltPWD.CopyTo(PWD, 0); //將加密後的值複製到新byte[]
SaltValue.CopyTo(PWD, SaltPWD.Length); //將Salted Value複製到新byte[]
txt_Result.Text = Convert.ToBase64String(PWD); //顯示Salted Hash後的字串

那個byte[]要放那個,那個byte[]要做什麼,很容易一不注意,就放錯個進去. 但這個加密後的如果如下:

值 : 123456789

Salted Value : goTest

結果 : erxXv9V5RYeCJaiF1z3yZ29UZXN0AA==

 

  因為這是目前仍無法反解回來的加密方式,所以就算DataBase的資料外流,也不用怕這些資料會被還原回來,而Salted Value就看大家要怎麼去"動"它囉.

原始碼 : encodeTest.rar


http://www.dotblogs.com.tw/jeff-yeh/archive/2008/06/25/4371.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值