一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - .NET中的DES對稱加密詳解

.NET中的DES對稱加密詳解

2019-11-18 13:47asp.net教程網 ASP.NET教程

DES是一種對稱加密(Data Encryption Standard)算法,于1977年得到美國政府的正式許可,是一種用56位密鑰來加密64位數據的方法。一般密碼長度為8個字節,其中56位加密密鑰,每個第8位都用作奇偶校驗

DES算法一般有兩個關鍵點,第一個是加密模式,第二個是數據補位,加密模式的主要意義就是,加密算法是按塊進行加密的,例如 DES ,是 64Bit 一個塊的進行加密,就是每次加密 8 個字節,因此每次輸入八個字節的明文輸出八個字節密文,如果是 16 個字節,那么分成兩個塊依次進行加密,問題就出現在這里,如果明文是 1234567812345678,分塊分別進行加密,那么加密的結果類似“C4132737962C519C C4132737962C519C”,可以看出明文的規律,這就是 ECB 加密模式,密文可以看出明文的規律;為了解決這個問題,有了其他的加密模式:CBC 加密模式(密碼分組連接),CFB加密模式(密碼反饋模式),OFB加密模式(輸出反饋模式)CBC 是要求給一個初始化的向量,然后將每個輸出與該向量作運算,并將運算的結果作為下一個加密塊的初始化向量,CFB 和 OFB 則不需要提供初始化向量,直接將密碼或者輸出作為初始化向量進行運算;這樣就避免了明文的規律出現在密文中;當然缺點是解密時需要保證密文的正確性,如果網絡傳輸時發生了一部分錯誤,則后面的解密結果就可能是錯誤的;(ECB模式僅影響傳輸錯誤的那個塊。密碼算法基本上都是分組(按快)進行加密的,如果密文長度不是剛剛好可以進行分組,怎么辦?只能進行填充。

加密算法常見的有ECB模式和CBC模式: 
第一種電子密本方式(ECB)  
      ECB模式:電子密本方式,就是將數據按照8個字節一段進行DES加密或解密得到一段8個字節的密文或者明文,最后一段不足8個字節,則補足8個字節(注意:這里就涉及到數據補位了)進行計算,之后按照順序將計算所得的數據連在一起即可,各段數據之間互不影響。將明文分成n個64比特分組,如果明文長度不是64比特的倍數,則在明文末尾填充適當數目的規定符號。對明文組用給定的密鑰分別進行加密,行密文C=(C0,C1,……,Cn-1)其中Ci=DES(K,xi),i=0,1,…..,n-1。 這是Java封裝的DES算法的默認模式. 
第二種密文分組鏈接方式(CBC)  

      密文分組鏈接方式,在CBC方式下,每個明文組xi在加密前與先一組密文按位模二加后,再送到DES加密,CBC方式克服了ECB方式報內組重的缺點,但由于明文組加密前與一組密文有關,因此前一組密文的錯誤會傳播到下一組。 這是.NET封裝的DES算法的默認模式,它比較麻煩,加密步驟如下:

1、首先將數據按照8個字節一組進行分組得到D1D2……Dn(若數據不是8的整數倍,就涉及到數據補位了)

2、第一組數據D1與向量I異或后的結果進行DES加密得到第一組密文C1(注意:這里有向量I的說法,ECB模式下沒有使用向量I)

3、第二組數據D2與第一組的加密結果C1異或以后的結果進行DES加密,得到第二組密文C2

4、之后的數據以此類推,得到Cn

5、按順序連為C1C2C3……Cn即為加密結果。

第三種密文反饋方式(CFB),可用于序列密碼 
   明文X=(x0,x1,……,xn-1),其中xi由t個比特組成0   第四種輸出反饋方式(OFB),可用于序列密碼 
   與CFB唯一不同的是OFB是直接取DES輸出的t個比特,而不是取密文的t個比特,其余都與CFB相同。但它取的是DES的輸出,所以它克服了CFB的密文錯誤傳播的缺點

數據補位一般有NoPadding和PKCS7Padding(Java中是PKCS5Padding)填充方式,PKCS7Padding和PKCS5Padding實際只是協議不一樣,根據相關資料說明:PKCS5Padding明確定義了加密塊是8字節,PKCS7Padding加密快可以是1-255之間。但是封裝的DES算法默認都是8字節,所以可以認為他們一樣。數據補位實際是在數據不滿8字節的倍數,才補充到8字節的倍數的填充過程。

NoPadding填充方式:算法本身不填充,比如.NET的padding提供了有None,Zeros方式,分別為不填充和填充0的方式。

PKCS7Padding(PKCS5Padding)填充方式:為.NET和Java的默認填充方式,對加密數據字節長度對8取余為r,如r大于0,則補8-r個字節,字節為8-r的值;如果r等于0,則補8個字節8.比如:

加密字符串為為AAA,則補位為AAA55555;加密字符串為BBBBBB,則補位為BBBBBB22;加密字符串為CCCCCCCC,則補位為CCCCCCCC88888888.

.NET中的DES加密

對于.NET,框架在System.Security.Cryptography命名空間下提供了DESCryptoServiceProvider作為System.Security.Cryptography.DES加密解密的包裝接口,它提供了如下的4個方法:

public override ICryptoTransform CreateDecryptor(byte[] rgbKey, byte[] rgbIV)

public override ICryptoTransform CreateEncryptor(byte[] rgbKey, byte[] rgbIV)

public override void GenerateIV()

public override void GenerateKey()

從.NET類庫封裝情況,加解密需要傳入一個Key和IV向量。而且Key必須為8字節的數據,否則會直接拋異常出來,當使用ECB模式下,不管傳入什么IV向量,加密結果都一樣。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 好大夫在线个人空间 | 人人福利 | 亚州精品永久观看视频 | 涩色爱| 香蕉免费看一区二区三区 | 91九色在线视频 | 精品国产欧美一区二区五十路 | 被老外玩爽的中国美女视频 | 成年人视频在线 | 91精品91| 暖暖视频日本 | 欧美同性video| 视频一区国产精戏刘婷 | 校草让我脱了内裤给全班看 | 22sihu国产精品视频影视资讯 | 色偷偷伊人| 亚洲视频在线观看不卡 | 日韩一区二区三 | 欧美理论片手机在线观看片免费 | 91久久线看在观草草青青 | 忘忧草秋观看未满十八 | 成人猫咪maomiav永久网址 | 婷婷综合七月激情啪啪 | 久久久免费观看 | 香蕉免费高清完整 | 韩国三级hd中文字幕李采潭 | 国产青草亚洲香蕉精品久久 | 性欧美sexovideotv| 91精品导航在线观看 | 双子母性本能在线 | 日韩特级片 | 四虎影视入口 | 国产日韩欧美在线一区二区三区 | 精品视频在线观看 | 91这里只有精品 | 爱豆传媒最新视频国产 | 国产99er66在线视频 | 肉搏潘金莲三级18春 | 丝袜性爱 | 爽好舒服快想要免费看 | 好大用力深一点 |