利用JAVA實現(xiàn)DES加密算法
更新時間:2013年08月30日 09:38:10 投稿:jingxian
本文簡單講解DES的JAVA實現(xiàn)方法。需要的朋友可以過來參考下
JAVA實現(xiàn)
加密
代碼有詳細解釋,不多廢話。
注意:DES加密和解密過程中,密鑰長度都必須是8的倍數(shù)
復制代碼 代碼如下:
public byte[] desCrypto(byte[] datasource, String password) {
try{
SecureRandom random = new SecureRandom();
DESKeySpec desKey = new DESKeySpec(password.getBytes());
//創(chuàng)建一個密匙工廠,然后用它把DESKeySpec轉換成
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;
}
解密
代碼有詳細注釋,不多廢話
復制代碼 代碼如下:
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對象轉換成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ù)對字符串進行加密解密,也可以對文件進行加密解密,如:
復制代碼 代碼如下:
//待加密內容
String str = "測試內容";
//密碼,長度要是8的倍數(shù)
String password = "12345678";
byte[] result = DESCrypto.desCrypto(str.getBytes(),password);
System.out.println("加密后內容為:"+new String(result));
//直接將如上內容解密
try {
byte[] decryResult = des.decrypt(result, password);
System.out.println("加密后內容為:"+new String(decryResult));
} catch (Exception e1) {
e1.printStackTrace();
}
相關文章
SQLSERVER2008中CTE的Split與CLR的性能比較
之前曾有一篇POST是關于用CTE實現(xiàn)Split,這種方法已經(jīng)比傳統(tǒng)的方法高效了。今天我們就這個方法與CLR實現(xiàn)的Split做比較。在CLR實現(xiàn)Split函數(shù)的確很簡單,dotnet framework本身就有這個function了。2011-10-10
SQL server 2008 數(shù)據(jù)庫優(yōu)化常用腳本
這篇文章主要介紹了SQL server 2008 數(shù)據(jù)庫優(yōu)化常用腳本,需要的朋友可以參考下2015-10-10
如何在SQL Server 2008下輕松調試T-SQL語句和存儲過程
sqlserver2008調試的要求和條件:如果在引擎所在的電腦或服務器上調試,則只需要SA或者WINDOWS用戶登陸即可。如果是異地調試,則需要設置防火墻例外,增加SSMS和SQLSERVER.EXE為允許,增加135端口允許通過2013-10-10
SQL SERVER 2008 r2 數(shù)據(jù)壓縮的兩種方法
這篇文章主要介紹了SQL SERVER 2008 r2 數(shù)據(jù)壓縮的兩種方法,腳本之家從多個網(wǎng)站整理的內容,需要的朋友可以參考下2018-03-03
Microsoft SQL Server 2008 基本安裝說明
這篇文章主要介紹了Microsoft SQL Server 2008 基本安裝說明 ,需要的朋友可以參考下2015-08-08
SqlServer 2008出現(xiàn)遠程過程調用失敗,錯誤代碼[Ox800706be]
本文主要介紹了在配置SQL Server 2008時遇到的遠程過程調用失敗問題及解決方法,包括卸載重新安裝、升級數(shù)據(jù)庫版本和更改安裝路徑,感興趣的可以了解一下2024-12-12
SQL Server 2008 數(shù)據(jù)庫中創(chuàng)建只讀用戶的方法
這篇文章主要介紹了SQL Server 2008 數(shù)據(jù)庫中創(chuàng)建只讀用戶的方法,為了保護數(shù)據(jù)庫的安全,需要給不同的使用者開通不同的訪問用戶,那么如何簡單的控制用戶的權限呢?下面我們就創(chuàng)建一個只讀用戶,給大家學習使用2015-08-08

