Java實現的對稱加密算法3DES定義與用法示例
本文實例講述了Java實現的對稱加密算法3DES定義與用法。分享給大家供大家參考,具體如下:
一 為什么出現3DES
1、返回柯克霍夫原則
2、存在安全問題
二 3DES(Triple DES或DESede)好處
1、密鑰長度增強
2、迭代次數提高
三 3DES相關參數

四 3DES代碼實現
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());//默認長度
SecretKey secretKey = keyGenerator.generateKey();
byte[] bytesKey = secretKey.getEncoded();
//KEY轉換
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();
}
}
}
五 實現效果
jdk 3des encrypt : 6t7A/RnarDZSl+MteZVBfxWnNZr0yjBw
jdk 3des decrypt : cakin24 security 3des
注:這里引入了org.apache.commons.codec.binary.Base64包,可點擊此處本站下載。
PS:關于加密解密感興趣的朋友還可以參考本站在線工具:
在線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
更多關于java相關內容感興趣的讀者可查看本站專題:《Java數學運算技巧總結》、《Java數據結構與算法教程》、《Java字符與字符串操作技巧總結》、《Java操作DOM節(jié)點技巧總結》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設計有所幫助。
相關文章
詳解使用Spring快速創(chuàng)建web應用的兩種方式
這篇文章主要介紹了詳解使用Spring快速創(chuàng)建web應用的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11
原因分析IDEA導入Spring-kafka項目Gradle編譯失敗
這篇文章主要為大家介紹分析了IDEA導入Spring-kafka項目Gradle中編譯失敗原因及解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-02-02
Springboot集成Ehcache3實現本地緩存的配置方法
EhCache是一個純Java的進程內緩存框架,是 Hibernate 中默認的 CacheProvider,同Redis一樣,EhCache 不是純內存緩存,它支持基于內存和磁盤的二級緩存,本文介紹Springboot集成Ehcache3實現本地緩存的配置方法,感興趣的朋友一起看看吧2024-04-04

