Java實(shí)現(xiàn)的對稱加密算法3DES定義與用法示例
本文實(shí)例講述了Java實(shí)現(xiàn)的對稱加密算法3DES定義與用法。分享給大家供大家參考,具體如下:
一 為什么出現(xiàn)3DES
1、返回柯克霍夫原則
2、存在安全問題
二 3DES(Triple DES或DESede)好處
1、密鑰長度增強(qiáng)
2、迭代次數(shù)提高
三 3DES相關(guān)參數(shù)
四 3DES代碼實(shí)現(xiàn)
package com.imooc.security.des; import java.security.Key; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESedeKeySpec; import org.apache.commons.codec.binary.Base64; public class Imooc3DES { private static String src = "cakin24 security 3des"; public static void main(String[] args) { jdk3DES(); } public static void jdk3DES() { try { //生成KEY KeyGenerator keyGenerator = KeyGenerator.getInstance("DESede"); //keyGenerator.init(168); keyGenerator.init(new SecureRandom());//默認(rèn)長度 SecretKey secretKey = keyGenerator.generateKey(); byte[] bytesKey = secretKey.getEncoded(); //KEY轉(zhuǎn)換 DESedeKeySpec desedeKeySpec = new DESedeKeySpec(bytesKey); SecretKeyFactory factory = SecretKeyFactory.getInstance("DESede"); Key convertSecretKey = factory.generateSecret(desedeKeySpec); //加密 Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, convertSecretKey); byte[] result = cipher.doFinal(src.getBytes()); System.out.println("jdk 3des encrypt : " + Base64.encodeBase64String(result)); //解密 cipher.init(Cipher.DECRYPT_MODE, convertSecretKey); result = cipher.doFinal(result); System.out.println("jdk 3des decrypt : " + new String(result)); } catch (Exception e) { e.printStackTrace(); } } }
五 實(shí)現(xiàn)效果
jdk 3des encrypt : 6t7A/RnarDZSl+MteZVBfxWnNZr0yjBw
jdk 3des decrypt : cakin24 security 3des
注:這里引入了org.apache.commons.codec.binary.Base64
包,可點(diǎn)擊此處本站下載。
PS:關(guān)于加密解密感興趣的朋友還可以參考本站在線工具:
在線DES加密/解密工具:
http://tools.jb51.net/password/des_encode
文字在線加密解密工具(包含AES、DES、RC4等):
http://tools.jb51.net/password/txt_encode
MD5在線加密工具:
http://tools.jb51.net/password/CreateMD5Password
在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha
在線sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode
更多關(guān)于java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)學(xué)運(yùn)算技巧總結(jié)》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java字符與字符串操作技巧總結(jié)》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計有所幫助。
- java 非對稱加密算法DH實(shí)現(xiàn)詳解
- java 非對稱加密算法RSA實(shí)現(xiàn)詳解
- JAVA加密算法- 非對稱加密算法(DH,RSA)的詳細(xì)介紹
- Java 實(shí)現(xiàn)對稱加密算法
- JAVA加密算法數(shù)字簽名實(shí)現(xiàn)原理詳解
- Java sm3加密算法的實(shí)現(xiàn)
- JAVA加密算法實(shí)密鑰一致協(xié)議代碼示例
- Java對稱加密算法DES實(shí)例詳解
- java實(shí)現(xiàn)可逆加密算法
- java實(shí)現(xiàn)AES可逆加密算法
- Java實(shí)現(xiàn)的Base64加密算法示例
- Java語言實(shí)現(xiàn)Blowfish加密算法完整代碼分享
- Java常用加密算法實(shí)例總結(jié)
- Java 實(shí)現(xiàn)常見的非對稱加密算法
相關(guān)文章
spring4.3 實(shí)現(xiàn)跨域CORS的方法
下面小編就為大家分享一篇spring4.3 實(shí)現(xiàn)跨域CORS的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01詳解使用Spring快速創(chuàng)建web應(yīng)用的兩種方式
這篇文章主要介紹了詳解使用Spring快速創(chuàng)建web應(yīng)用的兩種方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11原因分析IDEA導(dǎo)入Spring-kafka項(xiàng)目Gradle編譯失敗
這篇文章主要為大家介紹分析了IDEA導(dǎo)入Spring-kafka項(xiàng)目Gradle中編譯失敗原因及解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-02-02springboot中非容器類如何獲取配置文件數(shù)據(jù)
這篇文章主要介紹了springboot中非容器類如何獲取配置文件數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01Springboot集成Ehcache3實(shí)現(xiàn)本地緩存的配置方法
EhCache是一個純Java的進(jìn)程內(nèi)緩存框架,是 Hibernate 中默認(rèn)的 CacheProvider,同Redis一樣,EhCache 不是純內(nèi)存緩存,它支持基于內(nèi)存和磁盤的二級緩存,本文介紹Springboot集成Ehcache3實(shí)現(xiàn)本地緩存的配置方法,感興趣的朋友一起看看吧2024-04-04java哈希算法HashMap經(jīng)典面試題目匯總解析
這篇文章主要為大家介紹了java哈希算法HashMap的經(jīng)典面試題目匯總及問題解析,幫助大家徹底征服面試官,實(shí)現(xiàn)薪資自由,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03Java網(wǎng)絡(luò)編程之IO模型阻塞與非阻塞簡要分析
這篇文章主要介紹Java網(wǎng)絡(luò)編程中的IO模型阻塞與非阻塞簡要分析,文中附有示例代碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-09-09