利用JAVA實(shí)現(xiàn)DES加密算法
JAVA實(shí)現(xiàn)
加密
代碼有詳細(xì)解釋?zhuān)欢鄰U話(huà)。
注意:DES加密和解密過(guò)程中,密鑰長(zhǎng)度都必須是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ì)注釋?zhuān)欢鄰U話(huà)
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);
// 真正開(kāi)始解密操作
return cipher.doFinal(src);
}
測(cè)試場(chǎng)景
例如,我們可以利用如上函數(shù)對(duì)字符串進(jìn)行加密解密,也可以對(duì)文件進(jìn)行加密解密,如:
//待加密內(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();
}
相關(guān)文章
SQL2008 附加數(shù)據(jù)庫(kù)提示 5120錯(cuò)誤 解決辦法
SQL2008 附加數(shù)據(jù)庫(kù)提示 5120錯(cuò)誤 解決辦法,需要的朋友可以參考一下2013-03-03SQL Server 2008中SQL查詢(xún)語(yǔ)句字段值不區(qū)分大小寫(xiě)的問(wèn)題解決
這篇文章主要介紹了關(guān)于SQL Server 2008中SQL查詢(xún)語(yǔ)句字段值不區(qū)分大小寫(xiě)問(wèn)題的解決方法,文中將解決方法介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-07-07Java打印和打印預(yù)覽機(jī)制實(shí)例代碼
這篇文章主要介紹了Java打印和打印預(yù)覽機(jī)制實(shí)例代碼,有需要的朋友可以參考一下2014-01-01SQL Server 2008 新特性 總結(jié)復(fù)習(xí)(一)
寫(xiě)這篇文章,主要是總結(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ì)稱(chēng)密鑰加密
非對(duì)稱(chēng)密鑰包含數(shù)據(jù)庫(kù)級(jí)的內(nèi)部公鑰和私鑰,它可以用來(lái)加密和解密SQL Server數(shù)據(jù)庫(kù)中的數(shù)據(jù),它可以從外部文件或程序集中導(dǎo)入,也可以在SQL Server數(shù)據(jù)庫(kù)中生成。2011-06-06SQL SERVER 2008 R2配置管理器出現(xiàn)“遠(yuǎn)程過(guò)程調(diào)用失敗”(0x800706be)錯(cuò)誤提示
本文主要記錄了SQL SERVER 2008 R2配置管理器出現(xiàn)“遠(yuǎn)程過(guò)程調(diào)用失敗”(0x800706be)錯(cuò)誤提示的解決方法,圖文并茂,非常的實(shí)用,有需要的朋友可以參考下2014-10-10SQL SERVER 2008 中三種分頁(yè)方法與比較
SQL SERVER 2008 中三種分頁(yè)方法與比較,需要的朋友可以參考一下2013-04-04SQL Server 2008 評(píng)估期已過(guò)怎么解決
SQL Server 2008有180天的試用期,過(guò)期后會(huì)提示“評(píng)估期已過(guò)”的提示,本文給大家介紹SQL Server 2008 評(píng)估期已過(guò)的解決辦法,感興趣的朋友參考下吧2016-05-05