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

原创 2011年08月18日 10:56:00
 

下面用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();
     }
}

Java_加密解密之对称加密算法DES

  • 2015年07月30日 16:43
  • 30KB
  • 下载

Java 加密解密之对称加密算法DES

Java 加密解密之对称加密算法DES 博客分类:  Java Javajava des  Java 加密解密基础 Java byte数组与十六进制字符串互转 ...
  • JIESA
  • JIESA
  • 2016年11月14日 17:51
  • 278

Java 加密解密之对称加密算法DES

博客分类: Java Javajava des Java 加密解密基础 Java byte数组与十六进制字符串互转 Java BASE64加密解密 Java 加密解密之消息摘要算法(MD5 ...
  • aubdiy
  • aubdiy
  • 2016年05月27日 23:31
  • 495

Java 加密解密之对称加密算法DESede

ava 加密解密之对称加密算法DESede 博客分类:  Java Javajava desede  Java 加密解密基础 Java b...
  • JIESA
  • JIESA
  • 2016年11月14日 17:52
  • 309

http交互时java对称加密算法加密解密思想极致解析

加密解密代码: import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKe...

Java 加密解密之对称加密算法AES

Java 加密解密之对称加密算法AES 博客分类:  Java javajava aes  Java 加密解密基础 Java byte数组...
  • JIESA
  • JIESA
  • 2016年11月14日 17:53
  • 441

Java 加密解密之对称加密算法AES

Java 加密解密

Java 加密解密之对称加密算法AES

Java 加密解密之对称加密算法AES   密码学中的高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法,是美国联邦政府采用的一种...
  • snihcel
  • snihcel
  • 2014年05月23日 16:07
  • 538

Java 加密解密之对称加密算法DESede

Java 加密解密基础 Java byte数组与十六进制字符串互转 Java BASE64加密解密 Java 加密解密之消息摘要算法(MD5 SHA MAC) Java 加密解密之对称加密算法...
  • aubdiy
  • aubdiy
  • 2016年05月27日 23:33
  • 299

Java 加密解密之对称加密算法PBE

Java 加密解密之对称加密算法PBE PBE是一种基于口令的加密算法,使用口令代替其他对称加密算法中的密钥,其特点在于口令由用户自己掌管,不借助任何物理媒体;采用随机数(这里我们叫做盐)杂凑多...
  • lusai88
  • lusai88
  • 2012年03月27日 22:57
  • 2936
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JAVA加密解密DES对称加密算法
举报原因:
原因补充:

(最多只允许输入30个字)