DES加密介紹
DES是一種對(duì)稱加密算法,所謂對(duì)稱加密算法即:加密和解密使用相同密鑰的算法。DES加密算法出自IBM的研究,后來被美國(guó)政府正式采用,之后開始廣泛流傳,但是近些年使用越來越少,因?yàn)镈ES使用56位密鑰,以現(xiàn)代計(jì)算能力,24小時(shí)內(nèi)即可被破解。雖然如此,在某些簡(jiǎn)單應(yīng)用中,我們還是可以使用DES加密算法,本文簡(jiǎn)單講解DES的JAVA實(shí)現(xiàn)。
JAVA實(shí)現(xiàn)
加密
代碼有詳細(xì)解釋,不多廢話。
注意:DES加密和解密過程中,密鑰長(zhǎng)度都必須是8的倍數(shù)
復(fù)制代碼 代碼如下:
public byte[] desCrypto(byte[] datasource, String password) {
try{
SecureRandom random = new SecureRandom();
DESKeySpec desKey = new DESKeySpec(password.getBytes());
//創(chuàng)建一個(gè)密匙工廠,然后用它把DESKeySpec轉(zhuǎn)換成
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey securekey = keyFactory.generateSecret(desKey);
//Cipher對(duì)象實(shí)際完成加密操作
Cipher cipher = Cipher.getInstance("DES");
//用密匙初始化Cipher對(duì)象
cipher.init(Cipher.ENCRYPT_MODE, securekey, random);
//現(xiàn)在,獲取數(shù)據(jù)并加密
//正式執(zhí)行加密操作
return cipher.doFinal(datasource);
}catch(Throwable e){
e.printStackTrace();
}
return null;
}
解密
代碼有詳細(xì)注釋,不多廢話
復(fù)制代碼 代碼如下:
private byte[] decrypt(byte[] src, String password) throws Exception {
// DES算法要求有一個(gè)可信任的隨機(jī)數(shù)源
SecureRandom random = new SecureRandom();
// 創(chuàng)建一個(gè)DESKeySpec對(duì)象
DESKeySpec desKey = new DESKeySpec(password.getBytes());
// 創(chuàng)建一個(gè)密匙工廠
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
// 將DESKeySpec對(duì)象轉(zhuǎn)換成SecretKey對(duì)象
SecretKey securekey = keyFactory.generateSecret(desKey);
// Cipher對(duì)象實(shí)際完成解密操作
Cipher cipher = Cipher.getInstance("DES");
// 用密匙初始化Cipher對(duì)象
cipher.init(Cipher.DECRYPT_MODE, securekey, random);
// 真正開始解密操作
return cipher.doFinal(src);
}
測(cè)試場(chǎng)景
例如,我們可以利用如上函數(shù)對(duì)字符串進(jìn)行加密解密,也可以對(duì)文件進(jìn)行加密解密,如:
復(fù)制代碼 代碼如下:
//待加密內(nèi)容
String str = "測(cè)試內(nèi)容";
//密碼,長(zhǎng)度要是8的倍數(shù)
String password = "12345678";
byte[] result = DESCrypto.desCrypto(str.getBytes(),password);
System.out.println("加密后內(nèi)容為:"+new String(result));
//直接將如上內(nèi)容解密
try {
byte[] decryResult = des.decrypt(result, password);
System.out.println("加密后內(nèi)容為:"+new String(decryResult));
} catch (Exception e1) {
e1.printStackTrace();
}
您可能感興趣的文章:- 分享Java常用幾種加密算法(四種)
- java自帶的MessageDigest實(shí)現(xiàn)文本的md5加密算法
- 使用java自帶des加密算法實(shí)現(xiàn)文件加密和字符串加密
- java實(shí)現(xiàn)MD5加密算法的實(shí)例代碼
- java實(shí)現(xiàn)的AES加密算法完整實(shí)例
- java異或加密算法
- RSA加密算法java簡(jiǎn)單實(shí)現(xiàn)方法(必看)
- 詳解Java中實(shí)現(xiàn)SHA1與MD5加密算法的基本方法
- JAVA實(shí)現(xiàn)caesar凱撒加密算法
- java實(shí)現(xiàn)同態(tài)加密算法的實(shí)例代碼