java中以DES的方式實(shí)現(xiàn)對(duì)稱加密并提供密鑰的實(shí)例
java中以DES的方式實(shí)現(xiàn)對(duì)稱加密并提供密鑰的實(shí)例
加密原理
DES 使用一個(gè) 56 位的密鑰以及附加的 8 位奇偶校驗(yàn)位,產(chǎn)生最大 64 位的分組大小。這是一個(gè)迭代的分組密碼,使用稱為 Feistel 的技術(shù),其中將加密的文本塊分成兩半。使用子密鑰對(duì)其中一半應(yīng)用循環(huán)功能,然后將輸出與另一半進(jìn)行“異或”運(yùn)算;接著交換這兩半,這一過程會(huì)繼續(xù)下去,但最后一個(gè)循環(huán)不交換。DES 使用 16 個(gè)循環(huán),使用異或,置換,代換,移位操作四種基本運(yùn)算。
注釋都在代碼里了,干了:
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import javax.xml.bind.annotation.adapters.HexBinaryAdapter;
import org.apache.commons.codec.binary.Hex;
public class Main {
static String src = "Hello,sahadev!";
public static void main(String[] args) {
DES();
}
public static void DES() {
try {
// 以DES的方式初始化Key生成器
KeyGenerator keyGenerator = KeyGenerator.getInstance("DES");
keyGenerator.init(56);// 設(shè)置密鑰的長度為56位
// 生成一個(gè)Key
SecretKey generateKey = keyGenerator.generateKey();
// 轉(zhuǎn)變?yōu)樽止?jié)數(shù)組
byte[] encoded = generateKey.getEncoded();
// 生成密鑰字符串
String encodeHexString = Hex.encodeHexString(encoded);
System.out.println("Key : " + encodeHexString);
// 再把我們的字符串轉(zhuǎn)變?yōu)樽止?jié)數(shù)組,可以用于另一方使用,驗(yàn)證
byte[] decodeHex = Hex.decodeHex(encodeHexString.toCharArray());
// 生成密鑰對(duì)象
SecretKeySpec secretKeySpec = new SecretKeySpec(decodeHex, "DES");
// 獲取加解密實(shí)例
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
// 初始化加密模式
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
// 加密
byte[] doFinal = cipher.doFinal(src.getBytes());
System.out.println("加密結(jié)果 : " + new HexBinaryAdapter().marshal(doFinal));
// 初始化解密模式
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
// 解密
byte[] doFinal2 = cipher.doFinal(doFinal);
// 輸出解密結(jié)果
System.out.println("解密結(jié)果 : " + new String(doFinal2));
} catch (Exception e) {
e.printStackTrace();
}
}
}
附上輸出結(jié)果:
Key : 619b862f5e2aad40 加密結(jié)果 : D98FA80E83593710C0686370665C2FEC 解密結(jié)果 : Hello,sahadev!
以上就是java DES實(shí)現(xiàn)對(duì)稱加密的實(shí)例,如有疑問請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
Springboot容器級(jí)后置處理器BeanDefinitionRegistryPostProcessor
這篇文章主要介紹了Springboot容器級(jí)后置處理器BeanDefinitionRegistryPostProcessor,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-01-01
Feign調(diào)用中的兩種Header傳參方式小結(jié)
這篇文章主要介紹了Feign調(diào)用中的兩種Header傳參方式小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
JMeter參數(shù)化4種實(shí)現(xiàn)方式(小結(jié))
參數(shù)化是自動(dòng)化測試腳本的一種常用技巧,可將腳本中的某些輸入使用參數(shù)來代替,JMeter提供了多種參數(shù)化方式,下面就其中常用的4種展開闡述,感興趣的可以來了解一下2021-12-12
springboot整合JSR303參數(shù)校驗(yàn)與全局異常處理的方法
JSR-303 是 JAVA EE 6 中的一項(xiàng)子規(guī)范,叫做 Bean Validation,官方參考實(shí)現(xiàn)是Hibernate Validator,這篇文章主要介紹了springboot整合JSR303參數(shù)校驗(yàn)與全局異常處理,需要的朋友可以參考下2022-09-09
一篇文章帶你了解SpringMVC數(shù)據(jù)綁定
這篇文章主要給大家介紹了關(guān)于如何通過一篇文章弄懂Spring MVC的參數(shù)綁定,文中通過示例代碼以及圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2021-08-08
Java微信掃碼登錄功能并實(shí)現(xiàn)認(rèn)證授權(quán)全過程
這篇文章主要給大家介紹了關(guān)于Java微信掃碼登錄功能并實(shí)現(xiàn)認(rèn)證授權(quán)的相關(guān)資料,要在Java中實(shí)現(xiàn)微信掃碼登錄,您可以按照以下步驟進(jìn)行操作,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10

