des加密解密源碼 C# key值問(wèn)題分析
公司協(xié)議安全需求、需要對(duì)傳輸內(nèi)容做des、md5加密。
因?yàn)槭切氯?、剛交給我這個(gè)任務(wù)的時(shí)候有點(diǎn)眩暈。就開(kāi)始在網(wǎng)上找各種des加密的內(nèi)容。因?yàn)椴欢詾樾枰言硪哺忝靼?,最后誤了時(shí)間、把自己也搞糊涂了。當(dāng)然,邏輯能力強(qiáng)、有興趣的朋友可以試著去搞搞。
先貼加密、解密的源碼:
/// <summary>
/// 加密數(shù)據(jù)
/// </summary>
/// <param name="Text"></param>
/// <param name="sKey"></param>
/// <returns></returns>
public static string Encrypt(string Text, string sKey) {
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] inputByteArray;
inputByteArray = Encoding.Default.GetBytes(Text);
des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));
System.IO.MemoryStream ms = new System.IO.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);
}
return ret.ToString();
}
#endregion
/// <summary>
/// 解密數(shù)據(jù)
/// </summary>
/// <param name="Text"></param>
/// <param name="sKey"></param>
/// <returns></returns>
public static string Decrypt(string Text, string sKey) {
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
int len;
len = Text.Length / 2;
byte[] inputByteArray = new byte[len];
int x, i;
for (x = 0; x < len; x++) {
i = Convert.ToInt32(Text.Substring(x * 2, 2), 16);
inputByteArray[x] = (byte)i; }
des.Key = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));
des.IV = ASCIIEncoding.ASCII.GetBytes(System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(sKey, "md5").Substring(0, 8));
System.IO.MemoryStream ms = new System.IO.MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
return Encoding.Default.GetString(ms.ToArray()); }
#endregion
因?yàn)槭堑谝淮谓佑|des并且公司協(xié)議文檔的需求、讓我對(duì)這段代碼里面迷糊的有:
1:倆個(gè)參數(shù)
Text 是要加密的內(nèi)容
sKey是作為加密內(nèi)容的密鑰。當(dāng)然加密、解密時(shí)候的sKey值,是要保持一致的。
2:des對(duì)象的key值
這個(gè)key值和IV值是固定的8位長(zhǎng)度,一定要牢記。因?yàn)樵蹅兊膮?shù)sKey是不定長(zhǎng)度的、所以采取了一個(gè)方式就是對(duì)其進(jìn)行MD5加密、然后再截取他的前8位。這是為了在解密的時(shí)候保證key一致。不然會(huì)解密出錯(cuò)。
最后,我說(shuō)一下做為新人,我感覺(jué)牢記的幾個(gè)地方,或許是大大們眼中寫des必需的幾點(diǎn)~~別噴我啊、
幾個(gè)必要的對(duì)象:
DESCryptoServiceProvider 沒(méi)有它你想怎么des呢、嘿嘿
MemoryStream 存儲(chǔ)在內(nèi)存的流對(duì)象
CryptoStream 定義將數(shù)據(jù)流鏈接到加密轉(zhuǎn)換流。通過(guò)它寫入MemoryStream對(duì)象當(dāng)中
最后轉(zhuǎn)換成String。
- C#的3DES加密解密算法實(shí)例代碼
- C#編寫DES加密、解密類
- php實(shí)現(xiàn)和c#一致的DES加密解密實(shí)例
- C#使用DES和AES實(shí)現(xiàn)加密解密功能示例
- C# 3DES加密詳解
- c#通過(guò)DES加密算法加密大文件的方法
- C# DES加密算法中向量的作用詳細(xì)解析
- C#實(shí)現(xiàn)對(duì)AES加密和解密的方法
- 基于C#對(duì)用戶密碼使用MD5加密與解密
- asp實(shí)現(xiàn)的sha1加密解密代碼(和C#兼容)
- C#編寫的Base64加密和解密類
- C#實(shí)現(xiàn)簡(jiǎn)單的3DES加密解密功能示例
相關(guān)文章
C#實(shí)現(xiàn)修改系統(tǒng)時(shí)間的方法
這篇文章主要介紹了C#實(shí)現(xiàn)修改系統(tǒng)時(shí)間的方法,是一個(gè)非常實(shí)用的功能,需要的朋友可以參考下2014-07-07
C# Winform下載文件并顯示進(jìn)度條的實(shí)現(xiàn)代碼
本來(lái)是要研究怎樣判斷下載完成,結(jié)果找到這個(gè)方法,可以在這個(gè)方法完成之后提示下載完成,需要的朋友可以參考下2014-07-07
C#對(duì)Access進(jìn)行增刪改查的完整示例
本文主要是講C#對(duì)Access數(shù)據(jù)庫(kù)的增刪改查操作,想學(xué)習(xí)C#和Access數(shù)據(jù)庫(kù)操作基礎(chǔ)的可以參考借鑒,以下代碼都經(jīng)過(guò)實(shí)踐測(cè)試可用,下面跟著小編一起來(lái)看看。2016-08-08
c# 利用易福門振動(dòng)模塊VSE002采集振動(dòng)數(shù)據(jù)的方法
這篇文章主要介紹了c# 利用易福門振動(dòng)模塊VSE002采集振動(dòng)數(shù)據(jù)的方法,本文通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
C#.NET中如何批量插入大量數(shù)據(jù)到數(shù)據(jù)庫(kù)中
這篇文章主要給大家介紹C#.net中如何批量插入大量數(shù)據(jù)到數(shù)據(jù)庫(kù)中,本文涉及到C#.net中批量插入數(shù)據(jù)到數(shù)據(jù)庫(kù)中方面的內(nèi)容,對(duì)C#.net批量插入數(shù)據(jù)到數(shù)據(jù)庫(kù)中感興趣的朋友可以參考下本篇文章2015-10-10
一個(gè)C#開(kāi)發(fā)者重溫C++的心路歷程
作為一個(gè)C#開(kāi)發(fā)為什么要重新學(xué)習(xí)C++呢?因?yàn)樵贑#在很多業(yè)務(wù)場(chǎng)景需要調(diào)用一些C++編寫的COM組件,如果不了解C++,那么,很容易。。。注定是要被C++同事忽悠的2019-05-05

