利用JAVA實(shí)現(xiàn)DES加密算法
JAVA實(shí)現(xiàn)
加密
代碼有詳細(xì)解釋,不多廢話。
注意:DES加密和解密過程中,密鑰長度都必須是8的倍數(shù)
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ì)注釋,不多廢話
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)行加密解密,如:
//待加密內(nèi)容
String str = "測(cè)試內(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錯(cuò)誤 解決辦法
SQL2008 附加數(shù)據(jù)庫提示 5120錯(cuò)誤 解決辦法,需要的朋友可以參考一下2013-03-03SQL Server 2008中SQL查詢語句字段值不區(qū)分大小寫的問題解決
這篇文章主要介紹了關(guān)于SQL Server 2008中SQL查詢語句字段值不區(qū)分大小寫問題的解決方法,文中將解決方法介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-07-07Java打印和打印預(yù)覽機(jī)制實(shí)例代碼
這篇文章主要介紹了Java打印和打印預(yù)覽機(jī)制實(shí)例代碼,有需要的朋友可以參考一下2014-01-01SQL Server 2008 新特性 總結(jié)復(fù)習(xí)(一)
寫這篇文章,主要是總結(jié)最近學(xué)到的一些新知識(shí),這些特性不一定是SQLSERVER最新版才有,大多數(shù)是2008新特性,有些甚至是更早。如果有不懂的地方,建議大家去百度谷歌搜搜,本文不做詳細(xì)闡述,有錯(cuò)誤的地方,歡迎大家批評(píng)指正2012-07-07使用Navicat Premium將SQLServer數(shù)據(jù)導(dǎo)出為sql格式
這篇文章主要介紹了使用Navicat Premium將SQLServer數(shù)據(jù)導(dǎo)出為sql格式,需要的朋友可以參考下2016-12-12SQLServer 2008中的代碼安全(五) 非對(duì)稱密鑰加密
非對(duì)稱密鑰包含數(shù)據(jù)庫級(jí)的內(nèi)部公鑰和私鑰,它可以用來加密和解密SQL Server數(shù)據(jù)庫中的數(shù)據(jù),它可以從外部文件或程序集中導(dǎo)入,也可以在SQL Server數(shù)據(jù)庫中生成。2011-06-06SQL SERVER 2008 R2配置管理器出現(xiàn)“遠(yuǎn)程過程調(diào)用失敗”(0x800706be)錯(cuò)誤提示
本文主要記錄了SQL SERVER 2008 R2配置管理器出現(xiàn)“遠(yuǎn)程過程調(diào)用失敗”(0x800706be)錯(cuò)誤提示的解決方法,圖文并茂,非常的實(shí)用,有需要的朋友可以參考下2014-10-10SQL Server 2008 評(píng)估期已過怎么解決
SQL Server 2008有180天的試用期,過期后會(huì)提示“評(píng)估期已過”的提示,本文給大家介紹SQL Server 2008 評(píng)估期已過的解決辦法,感興趣的朋友參考下吧2016-05-05