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

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語言 - Java教程 - 詳解Java利用實現(xiàn)對稱加密(DES、3DES、AES)

詳解Java利用實現(xiàn)對稱加密(DES、3DES、AES)

2020-07-22 15:02郭朝 Java教程

本篇文章主要介紹了Java利用實現(xiàn)對稱加密(DES、3DES、AES),具有一定的參考價值,有興趣的可以了解一下。

有兩句話是這么說的:

1)算法和數(shù)據(jù)結(jié)構(gòu)就是編程的一個重要部分,你若失掉了算法和數(shù)據(jù)結(jié)構(gòu),你就把一切都失掉了。

2)編程就是算法和數(shù)據(jù)結(jié)構(gòu),算法和數(shù)據(jù)結(jié)構(gòu)是編程的靈魂。

注意,這可不是我說的,是無數(shù)程序員總結(jié)的,話說的很實在也很精辟,若想長久可持續(xù)發(fā)展,多研究算法還是很有必要的,今天我給大家說說加密算法中的對稱加密算法,并且這里將教會大家對稱加密算法的編程使用。包含DES、3DESAES三種對稱加密算法的編程使用,干貨滿滿。

1.對稱密碼算法

對稱密碼算法是當(dāng)今應(yīng)用范圍最廣,使用頻率最高的加密算法。它不僅應(yīng)用于軟件行業(yè),在硬件行業(yè)同樣流行。各種基礎(chǔ)設(shè)施凡是涉及到安全需求,都會優(yōu)先考慮對稱加密算法。

對稱密碼算法的加密密鑰和解密密鑰相同,對于大多數(shù)對稱密碼算法,加解密過程互逆。

(1)加解密通信模型

詳解Java利用實現(xiàn)對稱加密(DES、3DES、AES)

(2)特點:算法公開、計算量小、加密速度快、加密效率高

(3)弱點:雙方都使用同樣密鑰,安全性得不到保證

對稱密碼有流密碼和分組密碼兩種,但是現(xiàn)在普遍使用的是分組密碼:

(4)分組密碼工作模式

1)ECB:電子密碼本(最常用的,每次加密均產(chǎn)生獨立的密文分組,并且對其他的密文分組不會產(chǎn)生影響,也就是相同的明文加密后產(chǎn)生相同的密文)

2)CBC:密文鏈接(常用的,明文加密前需要先和前面的密文進行異或運算,也就是相同的明文加密后產(chǎn)生不同的密文)

除了這兩種常用的工作模式,還有:

3)CFB:密文反饋

4)OFB:輸出反饋

5)CTR:計數(shù)器

這五種工作模式主要是密碼學(xué)中算法在進行推導(dǎo)演算的時候所應(yīng)用到的。

6.分組密碼填充方式

1)NoPadding:無填充

2)PKCS5Padding:

3)ISO10126Padding:

7.常用對稱密碼:

1)DES(Data Encryption Standard,數(shù)據(jù)加密標準)

2)3DES(Triple DES、DESede,進行了三重DES加密的算法)

3)AES(Advanced Encryption Standard,高級數(shù)據(jù)加密標準,AES算法可以有效抵制針對DES的攻擊算法)
先來看一下這三種算法的簡單對比:

 

算法 密鑰長度 默認密鑰長度 工作模式 填充方式
DES 56 56 ECB、CBC、PCBC、CTR、CTS、CFB、CFB8-CFB128、OFB、OFB8-OFB128 NoPadding、PKCS5Padding、ISO10126Padding
3DES 112、168 168 ECB、CBC、PCBC、CTR、CTS、CFB、CFB8-CFB128、OFB、OFB8-OFB128 NoPadding、PKCS5Padding、ISO10126Padding
AES 128、192、256 128 ECB、CBC、PCBC、CTR、CTS、CFB、CFB8-CFB128、OFB、OFB8-OFB128 NoPadding、PKCS5Padding、ISO10126Padding

 

下面我們看如何使用 DES / 3DES / AES 三種算法實現(xiàn) 對稱加密:

2.DES算法

1.DES:數(shù)據(jù)加密標準,是對稱加密算法領(lǐng)域中的典型算法

2.特點:密鑰偏短(56位)、生命周期短(避免被破解)

3.Java實現(xiàn)

1)生成密鑰

?
1
2
3
4
KeyGenerator keyGen = KeyGenerator.getInstance("DES");//密鑰生成器
keyGen.init(56);//初始化密鑰生成器
SecretKey secretKey = keyGen.generateKey();//生成密鑰
byte[] key = secretKey.getEncoded();//密鑰字節(jié)數(shù)組

2)加密

?
1
2
3
4
SecretKey secretKey = new SecretKeySpec(key, "DES");//恢復(fù)密鑰
Cipher cipher = Cipher.getInstance("DES");//Cipher完成加密或解密工作類
cipher.init(Cipher.ENCRYPT_MODE, secretKey);//對Cipher初始化,加密模式
byte[] cipherByte = cipher.doFinal(data);//加密data

3)解密

?
1
2
3
4
SecretKey secretKey = new SecretKeySpec(key, "DES");//恢復(fù)密鑰
Cipher cipher = Cipher.getInstance("DES");//Cipher完成加密或解密工作類
cipher.init(Cipher.DECRYPT_MODE, secretKey);//對Cipher初始化,解密模式
byte[] cipherByte = cipher.doFinal(data);//解密data

我們可以發(fā)現(xiàn),加密解密我們只是設(shè)置了不同的模式而已。

3.3DES算法

1.3DES:將密鑰長度增至112位或168位,通過增加迭代次數(shù)提高安全性

2.缺點:處理速度較慢、密鑰計算時間較長、加密效率不高

3.Java實現(xiàn)

1)生成密鑰

?
1
2
3
4
KeyGenerator keyGen = KeyGenerator.getInstance("DESede");//密鑰生成器
keyGen.init(168); //可指定密鑰長度為112或168,默認為168
SecretKey secretKey = keyGen.generateKey();//生成密鑰
byte[] key = secretKey.getEncoded();//密鑰字節(jié)數(shù)組

2)3DES加密

?
1
2
3
4
SecretKey secretKey = new SecretKeySpec(key, "DESede");//恢復(fù)密鑰
Cipher cipher = Cipher.getInstance("DESede");//Cipher完成加密或解密工作類
cipher.init(Cipher.ENCRYPT_MODE, secretKey);//對Cipher初始化,解密模式
byte[] cipherByte = cipher.doFinal(data);//加密data

3)3DES解密

?
1
2
3
4
SecretKey secretKey = new SecretKeySpec(key, "DESede");//恢復(fù)密鑰
Cipher cipher = Cipher.getInstance("DESede");//Cipher完成加密或解密工作類
cipher.init(Cipher.DECRYPT_MODE, secretKey);//對Cipher初始化,解密模式
byte[] cipherByte = cipher.doFinal(data);//解密data

4.AES算法(推薦使用)

1.AES:高級數(shù)據(jù)加密標準,能夠有效抵御已知的針對DES算法的所有攻擊

2.特點:密鑰建立時間短、靈敏性好、內(nèi)存需求低、安全性高

3.Java實現(xiàn)

1)生成密鑰

?
1
2
3
4
KeyGenerator keyGen = KeyGenerator.getInstance("AES");//密鑰生成器
keygen.init(128); //默認128,獲得無政策權(quán)限后可為192或256
SecretKey secretKey = keyGen.generateKey();//生成密鑰
byte[] key = secretKey.getEncoded();//密鑰字節(jié)數(shù)組

2)AES加密

?
1
2
3
4
SecretKey secretKey = new SecretKeySpec(key, "AES");//恢復(fù)密鑰
Cipher cipher = Cipher.getInstance("AES");//Cipher完成加密或解密工作類
cipher.init(Cipher.ENCRYPT_MODE, secretKey);//對Cipher初始化,解密模式
byte[] cipherByte = cipher.doFinal(data);//加密data

3)AES解密

?
1
2
3
4
SecretKey secretKey = new SecretKeySpec(key, "AES");//恢復(fù)密鑰
Cipher cipher = Cipher.getInstance("AES");//Cipher完成加密或解密工作類
cipher.init(Cipher.DECRYPT_MODE, secretKey);//對Cipher初始化,解密模式
byte[] cipherByte = cipher.doFinal(data);//解密data

為了方便使用,我對DES / 3DES / AES 三種算法進行了工具類編寫,地址:下載地址 (新增DES/3DES/AES工具類)。

到此,DES / 3DES / AES 三種算法實現(xiàn) 對稱加密 就說完了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.csdn.net/smartbetter/article/details/54017759

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久国产精品免费网站 | 成全视频在线观看免费 | 亚洲一二三区久久五月天婷婷 | 337p大尺度啪啪人体午夜2020 | 毛片手机在线视频免费观看 | 日本b站一卡二不卡三卡四卡 | 韩国三级理韩国三级理人伦 | 美女脱了内裤让男生玩屁股 | 免费国产之a视频 | 午夜福到在线2019 | 千金肉奴隶在线观看 | 久久综合狠狠综合久久综合88 | ysl蜜桃色成人麻豆 youwu在线影院 | av在线色| 成 人免费va视频 | 草莓视频榴莲视频 | 欧美国产日产精品免费视频 | 秋霞黄色大片 | 五月最新女厕所高跟嘘嘘 | 成人久久网站 | 日本人与黑人做爰视频网站 | 四虎在线最新永久免费 | 三体动漫在线观看免费完整版2022 | 精品免费国产一区二区三区 | 色婷婷六月丁香在线观看 | 日韩大片在线 | 日本人和黑人一级纶理片 | 日本护士撒尿xxxxhd | 欧美高清在线精品一区 | 9999热视频 | 青青热久麻豆精品视频在线观看 | 国产精品高清一区二区三区不卡 | 四虎永久免费在线观看 | 大香人蕉免费视频75 | 大伊香蕉精品二区视频在线 | 日本96在线精品视频免费观看 | 99er热| 99精品国产美女福到在线不卡 | 91香蕉视频导航 | 亚洲国产精品一在线观看 | 国产精品自在欧美一区 |