a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C# > 正文

des加密解密源碼 C# key值問題分析

2020-01-24 02:57:26
字體:
供稿:網(wǎng)友

公司協(xié)議安全需求、需要對傳輸內(nèi)容做des、md5加密。

因為是新人、剛交給我這個任務的時候有點眩暈。就開始在網(wǎng)上找各種des加密的內(nèi)容。因為不懂以為需要把原理也搞明白,最后誤了時間、把自己也搞糊涂了。當然,邏輯能力強、有興趣的朋友可以試著去搞搞。

先貼加密、解密的源碼:

復制代碼 代碼如下:

/// <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

因為是第一次接觸des并且公司協(xié)議文檔的需求、讓我對這段代碼里面迷糊的有:

1:倆個參數(shù)

Text 是要加密的內(nèi)容

sKey是作為加密內(nèi)容的密鑰。當然加密、解密時候的sKey值,是要保持一致的。

2:des對象的key值

這個key值和IV值是固定的8位長度,一定要牢記。因為咱們的參數(shù)sKey是不定長度的、所以采取了一個方式就是對其進行MD5加密、然后再截取他的前8位。這是為了在解密的時候保證key一致。不然會解密出錯。

最后,我說一下做為新人,我感覺牢記的幾個地方,或許是大大們眼中寫des必需的幾點~~別噴我啊、

幾個必要的對象:

DESCryptoServiceProvider 沒有它你想怎么des呢、嘿嘿

MemoryStream    存儲在內(nèi)存的流對象

CryptoStream    定義將數(shù)據(jù)流鏈接到加密轉(zhuǎn)換流。通過它寫入MemoryStream對象當中

最后轉(zhuǎn)換成String。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲狠狠久久综合一区77777 | 欧美日韩激情在线 | 欧美在线视频一区 | a级淫片 | 91夜夜夜| 亚洲精品一区中文字幕乱码 | 精品日韩一区二区三区 | 91偷拍精品一区二区三区 | 羞羞小视频 | av一区在线| 成人免费视频网站在线观看 | 青青草在线免费视频 | 久久成人国产精品 | 久久久久综合狠狠综合日本高清 | 女男羞羞视频网站免费 | 中文字幕国产 | 欧美极品欧美精品欧美视频 | 大黄网站在线观看 | 狠狠操精品视频 | av一区在线观看 | 91精品国产色综合久久不卡98口 | 国产日韩欧美91 | 91亚洲精品久久久蜜桃网站 | 国产精品福利免费 | 日韩一区二区三区免费观看 | 毛片免费在线观看 | 日本在线免费播放 | 日韩中文字幕免费在线播放 | 日韩中文字幕无码一区二区三区 | 888av在线 | 成人午夜在线观看 | 久久青青 | 色网站免费看 | 91精品国产综合久久久蜜臀粉嫩 | 亚洲wu码 | a国产视频| 日韩成人av在线 | 成人免费网站www网站高清 | 天天狠天天天天透在线 | 亚洲精品日韩综合观看成人91 | 国产成人精品网站 |