Java實現(xiàn)的DES加密解密工具類實例
本文實例講述了Java實現(xiàn)的DES加密解密工具類。分享給大家供大家參考,具體如下:
一個工具類,很常用,不做深入研究了,那來可直接用
DesUtil.java
package lsy; import java.security.Key; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; public class DesUtil { /** * @param args */ public static void main(String[] args) { //以下是加密方法algorithm="AES"的測試 System.out.println(DesUtil.getInstance("lushuaiyin").getEnCodeString("hello")); //輸出 LDewGAZkmWHeYFjBz56ylw== //將上面的密文解密: System.out.println(DesUtil.getInstance("lushuaiyin").getDecodeString("LDewGAZkmWHeYFjBz56ylw==")); //輸出 hello //改變密鑰測試 System.out.println(DesUtil.getInstance("suolong").getEnCodeString("hello")); //輸出 /RLowOJ+Fr3KdMcdJeNatg== System.out.println(DesUtil.getInstance("suolong").getDecodeString("/RLowOJ+Fr3KdMcdJeNatg==")); //輸出 hello //如果使用不正確的密鑰解密,將會: System.out.println(DesUtil.getInstance("suolong").getDecodeString("LDewGAZkmWHeYFjBz56ylw==")); } private SecretKey key=null;//密鑰 //定義 加密算法,可用 DES,DESede,Blowfish,AES //不同的加密方式結果會不同 private static String algorithm="AES"; private static DesUtil desUtil=null; public DesUtil(){} public static DesUtil getInstance(String strKey){ desUtil=new DesUtil(); desUtil.createKey(strKey); return desUtil; } /** * algorithm 算法 * @param strKey */ public void createKey(String strKey){ try{ KeyGenerator kg=KeyGenerator.getInstance(DesUtil.algorithm); byte[] bt=strKey.getBytes("UTF-8"); SecureRandom sr=new SecureRandom(bt); kg.init(sr); this.setKey(kg.generateKey()); }catch(Exception e){ } } /** * 加密方法,返回密文 * cipher 密碼 * @param dataStr */ public String getEnCodeString(String dataStr){ byte[] miwen=null;//密文 byte[] mingwen=null;//明文 Cipher cipher; String result="";//密文字符串 try{ mingwen=dataStr.getBytes("UTF-8"); cipher=Cipher.getInstance(DesUtil.algorithm); cipher.init(Cipher.ENCRYPT_MODE, this.getKey()); miwen=cipher.doFinal(mingwen); BASE64Encoder base64en = new BASE64Encoder(); result=base64en.encodeBuffer(miwen);//或者可以用下面的方法得到密文,結果是不一樣的,都可以正常解密 // result=byte2hex(miwen);//密文結果類似2C:37:B0:18:06:64:99:61:DE:60:58:C1:CF:9E:B2:97 }catch(Exception e){ e.printStackTrace(); } return result; } /** * 解密方法,返回明文 * @param codeStr * @return */ public String getDecodeString(String codeStr){ BASE64Decoder base64De = new BASE64Decoder(); byte[] miwen=null; byte[] mingwen=null; String resultData="";//返回的明文 Cipher cipher; try{ miwen=base64De.decodeBuffer(codeStr); cipher=Cipher.getInstance(DesUtil.algorithm); cipher.init(Cipher.DECRYPT_MODE, this.getKey()); mingwen=cipher.doFinal(miwen); resultData = new String(mingwen,"UTF-8"); }catch(Exception e){ return "密鑰不正確或其他原因導致異常,無法解密!"; } return resultData; } //二行制轉字符串 public String byte2hex(byte[] b) { String hs = ""; String stmp = ""; for (int n = 0; n < b.length; n++) { stmp = (java.lang.Integer.toHexString(b[n] & 0XFF)); if (stmp.length() == 1) hs = hs + "0" + stmp; else hs = hs + stmp; if (n < b.length - 1) hs = hs + ":"; } return hs.toUpperCase(); } public SecretKey getKey() { return key; } public void setKey(SecretKey key) { this.key = key; } public static String getAlgorithm() { return algorithm; } public static void setAlgorithm(String algorithm) { algorithm = algorithm; } }
運行結果:
LDewGAZkmWHeYFjBz56ylw== hello /RLowOJ+Fr3KdMcdJeNatg== hello 密鑰不正確或其他原因導致異常,無法解密!
PS:關于加密解密感興趣的朋友還可以參考本站在線工具:
在線DES加密/解密工具:
http://tools.jb51.net/password/des_encode
文字在線加密解密工具(包含AES、DES、RC4等):
http://tools.jb51.net/password/txt_encode
MD5在線加密工具:
http://tools.jb51.net/password/CreateMD5Password
在線散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha
更多關于java相關內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)學運算技巧總結》、《Java數(shù)據(jù)結構與算法教程》、《Java字符與字符串操作技巧總結》、《Java操作DOM節(jié)點技巧總結》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設計有所幫助。
相關文章
Spring.Net在MVC中實現(xiàn)注入的原理解析
這篇文章主要介紹了Spring.Net在MVC中實現(xiàn)注入的原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-09-09java:無法訪問org.springframework.boot.SpringApplication問題
這篇文章主要介紹了java:無法訪問org.springframework.boot.SpringApplication問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08Springboot詳解整合SpringSecurity實現(xiàn)全過程
Spring Security基于Spring開發(fā),項目中如果使用Springboot作為基礎,配合Spring Security做權限更加方便,而Shiro需要和Spring進行整合開發(fā)。因此作為spring全家桶中的Spring Security在java領域很常用2022-07-07利用Spring Validation實現(xiàn)輸入驗證功能
這篇文章主要給大家介紹了如何利用Spring Validation完美的實現(xiàn)輸入驗證功能,文中有詳細的代碼示例,具有一定的參考價值,感興趣的朋友可以借鑒一下2023-06-06java實現(xiàn)二叉樹的創(chuàng)建及5種遍歷方法(總結)
下面小編就為大家?guī)硪黄猨ava實現(xiàn)二叉樹的創(chuàng)建及5種遍歷方法(總結)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04