您的位置:首页 > 编程语言 > Java开发

JAVA加密解密DES对称加密算法

2015-08-01 15:46 716 查看
文章来源:http://blog.csdn.net/forlong401/article/details/7192980

/article/9660291.html

下面用DES对称加密算法(设定一个密钥,然后对所有的数据进行加密)来简单举个例子。

首先,生成一个密钥KEY。

我把它保存到key.txt中。这个文件就象是一把钥匙。谁拥有它,谁就能解开我们的类文件。代码参考如下:

package com.neusoft.jiami;

import java.io.File;

import java.io.FileOutputStream;

import java.security.SecureRandom;

import javax.crypto.KeyGenerator;

import javax.crypto.SecretKey;

class Key {

private String keyName;

public Key(String keyName) {

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算法要求有一个可信任的随机数源

SecureRandom sr = new SecureRandom();

// 获得密匙数据

FileInputStream fi = new FileInputStream(new File("key.txt"));

byte rawKeyData[] = new byte[fi.available()];

fi.read(rawKeyData);

fi.close();

// 从原始密匙数据创建DESKeySpec对象

DESKeySpec dks = new DESKeySpec(rawKeyData);

// 创建一个密匙工厂,然后用它把DESKeySpec转换成一个SecretKey对象

SecretKey key = SecretKeyFactory.getInstance("DES").generateSecret(dks);

// Cipher对象实际完成加密操作

Cipher cipher = Cipher.getInstance("DES");

// 用密匙初始化Cipher对象

cipher.init(Cipher.ENCRYPT_MODE, key, sr);

// 现在,获取要加密的文件数据

FileInputStream fi2 = new FileInputStream(new File("DigestPass.class"));

byte data[] = new byte[fi2.available()];

fi2.read(data);

fi2.close();

// 正式执行加密操作

byte encryptedData[] = cipher.doFinal(data);

// 用加密后的数据覆盖原文件

FileOutputStream fo = new FileOutputStream(new File("DigestPass.class"));

fo.write(encryptedData);

fo.close();

}

}

第三步,用自定义的CLASSLOADER进行加载。参考代码如下:

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;

import com.neusoft.classloader.MyClassLoader;

public class JieMi {

public static void main(String[] args) throws Exception {
// DES算法要求有一个可信任的随机数源

SecureRandom sr = new SecureRandom();

// 获得密匙数据

FileInputStream fi = new FileInputStream(new File("key.txt"));

byte rawKeyData[] = new byte[fi.available()];// = new byte[5];

fi.read(rawKeyData);

fi.close();

// 从原始密匙数据创建一个DESKeySpec对象

DESKeySpec dks = new DESKeySpec(rawKeyData);

// 创建一个密匙工厂,然后用它把DESKeySpec对象转换成一个SecretKey对象

SecretKey key = SecretKeyFactory.getInstance("DES").generateSecret(dks);

// Cipher对象实际完成解密操作

Cipher cipher = Cipher.getInstance("DES");

// 用密匙初始化Cipher对象

cipher.init(Cipher.DECRYPT_MODE, key, sr);

// 现在,获取数据并解密

FileInputStream fi2 = new FileInputStream(new File("DigestPass.class"));

byte encryptedData[] = new byte[fi2.available()];

fi2.read(encryptedData);

fi2.close();

// 正式执行解密操作

byte decryptedData[] = cipher.doFinal(encryptedData);

// 这时把数据还原成原有的类文件

// FileOutputStream fo = new FileOutputStream(new

// File("DigestPass.class"));

// fo.write(decryptedData);

// 用解密后的数据加载类并应用

MyClassloader mcl = new MyClassloader("E:/");

Class cl = mcl.loadClass(decryptedData, "com.neusoft.jiami.DigestPass");

DigestPass dp = cl.newInstance();

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: