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 }