this.keyName = keyName; }
public void createKey(String keyName) throws Exception {
// 创建一个可信任的随机数源,DES算法需要 SecureRandom sr = new SecureRandom(); // 用DES算法创建一个KeyGenerator对象 KeyGenerator kg = KeyGenerator.getInstance("DES"); // 初始化此密钥生成器,使其具有确定的密钥长度 kg.init(sr); // 生成密匙 SecretKey key = kg.generateKey(); // 获取密钥数据 byte rawKeyData[] = key.getEncoded(); // 将获取到密钥数据保存到文件中,待解密时使用 FileOutputStream fo = new FileOutputStream(new File(keyName)); fo.write(rawKeyData); }
public static void main(String args[]) { try { new Key("key.txt"); } catch (Exception e) { e.printStackTrace(); }
} }进入讨论组讨论。 第二步,对我们所要进行加密的类文件进行加密。
比如我有一个DigestPass类,已经被正常编译好生成DigestPass.class文件。此时,这个类文件是任何人都可以用的。因为系统的类加载器可以自动的加载它。那么下一步,我们要做的就是把这个类文件加密。使系统的类加载器无法读取到正确的字节码文件。参考代码如下: package com.neusoft.jiami;
import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.security.SecureRandom;
import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec;
public class JiaMi {
public static void main(String[] args) throws Exception {
// DES算法要求有一个可信任的随机数源
上一篇:Guice与Spring框架的区别
下一篇:Hibernate项目中工具箱指南
|