利用JAVA實現(xiàn)DES加密算法
更新時間:2013年08月30日 09:38:10 投稿:jingxian
本文簡單講解DES的JAVA實現(xiàn)方法。需要的朋友可以過來參考下
JAVA實現(xiàn)
加密
代碼有詳細解釋,不多廢話。
注意:DES加密和解密過程中,密鑰長度都必須是8的倍數(shù)
復(fù)制代碼 代碼如下:
public byte[] desCrypto(byte[] datasource, String password) {
try{
SecureRandom random = new SecureRandom();
DESKeySpec desKey = new DESKeySpec(password.getBytes());
//創(chuàng)建一個密匙工廠,然后用它把DESKeySpec轉(zhuǎn)換成
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey securekey = keyFactory.generateSecret(desKey);
//Cipher對象實際完成加密操作
Cipher cipher = Cipher.getInstance("DES");
//用密匙初始化Cipher對象
cipher.init(Cipher.ENCRYPT_MODE, securekey, random);
//現(xiàn)在,獲取數(shù)據(jù)并加密
//正式執(zhí)行加密操作
return cipher.doFinal(datasource);
}catch(Throwable e){
e.printStackTrace();
}
return null;
}
解密
代碼有詳細注釋,不多廢話
復(fù)制代碼 代碼如下:
private byte[] decrypt(byte[] src, String password) throws Exception {
// DES算法要求有一個可信任的隨機數(shù)源
SecureRandom random = new SecureRandom();
// 創(chuàng)建一個DESKeySpec對象
DESKeySpec desKey = new DESKeySpec(password.getBytes());
// 創(chuàng)建一個密匙工廠
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
// 將DESKeySpec對象轉(zhuǎn)換成SecretKey對象
SecretKey securekey = keyFactory.generateSecret(desKey);
// Cipher對象實際完成解密操作
Cipher cipher = Cipher.getInstance("DES");
// 用密匙初始化Cipher對象
cipher.init(Cipher.DECRYPT_MODE, securekey, random);
// 真正開始解密操作
return cipher.doFinal(src);
}
測試場景
例如,我們可以利用如上函數(shù)對字符串進行加密解密,也可以對文件進行加密解密,如:
復(fù)制代碼 代碼如下:
//待加密內(nèi)容
String str = "測試內(nèi)容";
//密碼,長度要是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();
}
相關(guān)文章
SQL2008 附加數(shù)據(jù)庫提示 5120錯誤 解決辦法
SQL2008 附加數(shù)據(jù)庫提示 5120錯誤 解決辦法,需要的朋友可以參考一下2013-03-03SQL Server 2008中SQL查詢語句字段值不區(qū)分大小寫的問題解決
這篇文章主要介紹了關(guān)于SQL Server 2008中SQL查詢語句字段值不區(qū)分大小寫問題的解決方法,文中將解決方法介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-07-07SQL Server 2008 新特性 總結(jié)復(fù)習(xí)(一)
寫這篇文章,主要是總結(jié)最近學(xué)到的一些新知識,這些特性不一定是SQLSERVER最新版才有,大多數(shù)是2008新特性,有些甚至是更早。如果有不懂的地方,建議大家去百度谷歌搜搜,本文不做詳細闡述,有錯誤的地方,歡迎大家批評指正2012-07-07使用Navicat Premium將SQLServer數(shù)據(jù)導(dǎo)出為sql格式
這篇文章主要介紹了使用Navicat Premium將SQLServer數(shù)據(jù)導(dǎo)出為sql格式,需要的朋友可以參考下2016-12-12SQLServer 2008中的代碼安全(五) 非對稱密鑰加密
非對稱密鑰包含數(shù)據(jù)庫級的內(nèi)部公鑰和私鑰,它可以用來加密和解密SQL Server數(shù)據(jù)庫中的數(shù)據(jù),它可以從外部文件或程序集中導(dǎo)入,也可以在SQL Server數(shù)據(jù)庫中生成。2011-06-06SQL SERVER 2008 R2配置管理器出現(xiàn)“遠程過程調(diào)用失敗”(0x800706be)錯誤提示
本文主要記錄了SQL SERVER 2008 R2配置管理器出現(xiàn)“遠程過程調(diào)用失敗”(0x800706be)錯誤提示的解決方法,圖文并茂,非常的實用,有需要的朋友可以參考下2014-10-10