JAVA加密解密DES對稱加密算法

 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 }
相關文章
相關標籤/搜索