Des加解密
阿新 • • 發佈:2018-03-21
轉字符串 pri rgs str 自己 rst public 初始化 工具
import java.security.*; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; /** * 字符串加密解密工具,可逆加密,秘鑰很重要,一定要自己改秘鑰,打死也不要告訴其他人 * @author 夏增明 * @version 1.0 Date:2013年2月8日15:45:56 */ public class DesUtil { // 密鑰,是加密解密的憑據,長度為8的倍數private static final String PASSWORD_CRYPT_KEY = "12345678"; private final static String DES = "DES"; /** * 加密 * @param src 數據源 * @param key 密鑰,長度必須是8的倍數 * @return 返回加密後的數據 * @throws Exception */ public static byte[] encrypt(byte[] src, byte[] key) throwsException { // DES算法要求有一個可信任的隨機數源 SecureRandom sr = new SecureRandom(); // 從原始密匙數據創建DESKeySpec對象 DESKeySpec dks = new DESKeySpec(key); // 創建一個密匙工廠,然後用它把DESKeySpec轉換成 // 一個SecretKey對象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES); SecretKey securekey= keyFactory.generateSecret(dks); // Cipher對象實際完成加密操作 Cipher cipher = Cipher.getInstance(DES); // 用密匙初始化Cipher對象 cipher.init(Cipher.ENCRYPT_MODE, securekey, sr); // 現在,獲取數據並加密 // 正式執行加密操作 return cipher.doFinal(src); } /** * 解密 * @param src 數據源 * @param key 密鑰,長度必須是8的倍數 * @return 返回解密後的原始數據 * @throws Exception */ public static byte[] decrypt(byte[] src, byte[] key) throws Exception { // DES算法要求有一個可信任的隨機數源 SecureRandom sr = new SecureRandom(); // 從原始密匙數據創建一個DESKeySpec對象 DESKeySpec dks = new DESKeySpec(key); // 創建一個密匙工廠,然後用它把DESKeySpec對象轉換成 // 一個SecretKey對象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES); SecretKey securekey = keyFactory.generateSecret(dks); // Cipher對象實際完成解密操作 Cipher cipher = Cipher.getInstance(DES); // 用密匙初始化Cipher對象 cipher.init(Cipher.DECRYPT_MODE, securekey, sr); // 現在,獲取數據並解密 // 正式執行解密操作 return cipher.doFinal(src); } /** * 密碼解密 * @param data * @return * @throws Exception */ public final static String decrypt(String data) { try { return new String(decrypt(hex2byte(data.getBytes()), PASSWORD_CRYPT_KEY.getBytes())); } catch (Exception e) { } return null; } /** * 密碼加密 * @param password * @return * @throws Exception */ public final static String encrypt(String password) { try { return byte2hex(encrypt(password.getBytes(), PASSWORD_CRYPT_KEY.getBytes())); } catch (Exception e) { } return null; } /** * 二行制轉字符串 * @param b * @return */ public static 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; } return hs.toUpperCase(); } public static byte[] hex2byte(byte[] b) { if ((b.length % 2) != 0) throw new IllegalArgumentException("長度不是偶數"); byte[] b2 = new byte[b.length / 2]; for (int n = 0; n < b.length; n += 2) { String item = new String(b, n, 2); b2[n / 2] = (byte) Integer.parseInt(item, 16); } return b2; } // 測試用例,不需要傳遞任何參數,直接執行即可。 public static void main(String[] args) { String basestr = "this is 我的 #$%^&()first encrypt program 知道嗎?DES算法要求有一個可信任的隨機數源 --//*。@@@1"; String str1 = encrypt(basestr); System.out.println("原始值: " + basestr); System.out.println("加密後: " + str1); System.out.println("解密後: " + decrypt(str1)); System.out.println("為空時 is : " + decrypt(encrypt(""))); } }
Des加解密