1 下面用DES對稱加密算法(設定一個密鑰,而後對全部的數據進行加密)來簡單舉個例子。 2
3 首先,生成一個密鑰KEY。 4 我把它保存到key.txt中。這個文件就象是一把鑰匙。誰擁有它,誰就能解開咱們的類文件。代碼參考以下: 5 package com.neusoft.jiami; 6 import Java.io.File; 7 import java.io.FileOutputStream; 8 import java.security.SecureRandom; 9 import javax.crypto.KeyGenerator; 10 import javax.crypto.SecretKey; 11 class Key { 12 private String keyName; 13 public Key(String keyName) { 14 this.keyName = keyName; 15 } 16 public void createKey(String keyName) throws Exception { 17 // 建立一個可信任的隨機數源,DES算法須要
18 SecureRandom sr = new SecureRandom(); 19 // 用DES算法建立一個KeyGenerator對象
20 KeyGenerator kg = KeyGenerator.getInstance("DES"); 21 // 初始化此密鑰生成器,使其具備肯定的密鑰長度
22 kg.init(sr); 23 // 生成密匙
24 SecretKey key = kg.generateKey(); 25 // 獲取密鑰數據
26 byte rawKeyData[] = key.getEncoded(); 27 // 將獲取到密鑰數據保存到文件中,待解密時使用
28 FileOutputStream fo = new FileOutputStream(new File(keyName)); 29 fo.write(rawKeyData); 30 } 31 public static void main(String args[]) { 32 try { 33 new Key("key.txt"); 34 } catch (Exception e) { 35 e.printStackTrace(); 36 } 37 } 38 } 39 第二步,對咱們所要進行加密的類文件進行加密。 40 好比我有一個DigestPass類,已經被正常編譯好生成DigestPass.class文件。此時,這個類文件是任何人均可以用的。由於系統的類加載器能夠自動的加載它。那麼下一步,咱們要作的就是把這個類文件加密。使系統的類加載器沒法讀取到正確的字節碼文件。參考代碼以下: 41 package com.neusoft.jiami; 42 import java.io.File; 43 import java.io.FileInputStream; 44 import java.io.FileOutputStream; 45 import java.security.SecureRandom; 46 import javax.crypto.Cipher; 47 import javax.crypto.SecretKey; 48 import javax.crypto.SecretKeyFactory; 49 import javax.crypto.spec.DESKeySpec; 50 public class JiaMi { 51 public static void main(String[] args) throws Exception { 52 // DES算法要求有一個可信任的隨機數源
53 SecureRandom sr = new SecureRandom(); 54 // 得到密匙數據
55 FileInputStream fi = new FileInputStream(new File("key.txt")); 56 byte rawKeyData[] = new byte[fi.available()]; 57 fi.read(rawKeyData); 58 fi.close(); 59 // 從原始密匙數據建立DESKeySpec對象
60 DESKeySpec dks = new DESKeySpec(rawKeyData); 61 // 建立一個密匙工廠,而後用它把DESKeySpec轉換成一個SecretKey對象
62 SecretKey key = SecretKeyFactory.getInstance("DES").generateSecret(dks); 63 // Cipher對象實際完成加密操做
64 Cipher cipher = Cipher.getInstance("DES"); 65 // 用密匙初始化Cipher對象
66 cipher.init(Cipher.ENCRYPT_MODE, key, sr); 67 // 如今,獲取要加密的文件數據
68 FileInputStream fi2 = new FileInputStream(new File("DigestPass.class")); 69 byte data[] = new byte[fi2.available()]; 70 fi2.read(data); 71 fi2.close(); 72 // 正式執行加密操做
73 byte encryptedData[] = cipher.doFinal(data); 74 // 用加密後的數據覆蓋原文件
75 FileOutputStream fo = new FileOutputStream(new File("DigestPass.class")); 76 fo.write(encryptedData); 77 fo.close(); 78 } 79 } 80 第三步,用自定義的CLASSLOADER進行加載。參考代碼以下: 81 package com.neusoft.jiami; 82 import java.io.File; 83 import java.io.FileInputStream; 84 import java.io.FileOutputStream; 85 import java.security.SecureRandom; 86 import javax.crypto.Cipher; 87 import javax.crypto.SecretKey; 88 import javax.crypto.SecretKeyFactory; 89 import javax.crypto.spec.DESKeySpec; 90 import com.neusoft.classloader.MyClassLoader; 91 public class JieMi { 92 public static void main(String[] args) throws Exception { 93 // DES算法要求有一個可信任的隨機數源
94 SecureRandom sr = new SecureRandom(); 95 // 得到密匙數據
96 FileInputStream fi = new FileInputStream(new File("key.txt")); 97 byte rawKeyData[] = new byte[fi.available()];// = new byte[5];
98 fi.read(rawKeyData); 99 fi.close(); 100 // 從原始密匙數據建立一個DESKeySpec對象
101 DESKeySpec dks = new DESKeySpec(rawKeyData); 102 // 建立一個密匙工廠,而後用它把DESKeySpec對象轉換成一個SecretKey對象
103 SecretKey key = SecretKeyFactory.getInstance("DES").generateSecret(dks); 104 // Cipher對象實際完成解密操做
105 Cipher cipher = Cipher.getInstance("DES"); 106 // 用密匙初始化Cipher對象
107 cipher.init(Cipher.DECRYPT_MODE, key, sr); 108 // 如今,獲取數據並解密
109 FileInputStream fi2 = new FileInputStream(new File("DigestPass.class")); 110 byte encryptedData[] = new byte[fi2.available()]; 111 fi2.read(encryptedData); 112 fi2.close(); 113 // 正式執行解密操做
114 byte decryptedData[] = cipher.doFinal(encryptedData); 115 // 這時把數據還原成原有的類文件 116 // FileOutputStream fo = new FileOutputStream(new 117 // File("DigestPass.class")); 118 // fo.write(decryptedData); 119 // 用解密後的數據加載類並應用
120 MyClassloader mcl = new MyClassloader("E:/"); 121 Class cl = mcl.loadClass(decryptedData, "com.neusoft.jiami.DigestPass"); 122 DigestPass dp = cl.newInstance(); 123 } 124 }