JAVA加密程序

package com.test;

import java.io.DataInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.security.NoSuchAlgorithmException;
import java.security.Provider;
import java.security.Security;
import java.util.Arrays;

import javax.crypto.Cipher;
import javax.crypto.CipherOutputStream;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESedeKeySpec;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import junit.framework.TestCase;

/**
 *
 * @author 杜东辉 2006年9月15日
 *
 */
public class TestEncrypt extends TestCase {

 /**
  * 日志
  */
 public static final Log log = LogFactory.getLog(TestEncrypt.class);

 /**
  * 创建一个文件
  */
 static File keyfile = new File("G://key.txt");

 /**
  * 测试加密
  *
  * @throws Exception
  */
 public void testEncrypt() throws Exception {

  try {
   // 检测是否有加密程序
   // 此类提供加密和解密功能
   Cipher cipher = Cipher.getInstance("DESede");
  } catch (Exception e) {
   // 安装JCE提供程序
   Provider sunjce = new com.sun.crypto.provider.SunJCE();
   Security.addProvider(sunjce);

  }
  // 生成密钥并保存到文件
  if (keyfile.length() == 0) {
   SecretKey key = this.generateKey();
   this.writeKey(key, keyfile);
  }
  // 读密钥文件
  SecretKey key = this.readKey(keyfile);

  String testText = "ddh";
  // 加密
  byte[] bytes = this.encrypt(key, testText);

  // 解密
  String text = this.decrypt(key, bytes);

  if (log.isInfoEnabled()) {

   log.info("加密前: " + testText);
   log.info("加密后:" + bytes);
   log.info("解密后:" + text);

  }

 }

 /**
  * 生成密钥
  *
  * @return SecretKey
  * @throws Exception
  */
 public static SecretKey generateKey() throws Exception {

  // 获取密钥生成器
  KeyGenerator keyGen = KeyGenerator.getInstance("DESede");
  // 产生密钥
  SecretKey key = keyGen.generateKey();

  return key;

 }

 /**
  * 保存密钥到指定文件
  *
  * @param key
  * @param f
  * @throws Exception
  */
 public static void writeKey(SecretKey key, File f) throws Exception {
  // 将密钥转换为字节数据
  SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("DESede");
  DESedeKeySpec keyspec = (DESedeKeySpec) keyfactory.getKeySpec(key,
    DESedeKeySpec.class);
  byte[] rawkey = keyspec.getKey();
  // 将原始密钥写入文件
  FileOutputStream out = new FileOutputStream(keyfile);
  out.write(rawkey);
  out.close();

 }

 /**
  *
  * 从指定文件读入密钥
  *
  * @param f
  * @return
  * @throws Exception
  */
 public static SecretKey readKey(File f) throws Exception {
  // 读入原始字节
  DataInputStream in = new DataInputStream(new FileInputStream(f));
  byte[] rawKey = new byte[(int) f.length()];
  in.readFully(rawKey);
  in.close();

  // 将原始字节转换为密钥
  DESedeKeySpec keyspec = new DESedeKeySpec(rawKey);
  SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("DESede");
  SecretKey key = keyfactory.generateSecret(keyspec);

  return key;

 }

 /**
  * 加密
  *
  * @param key
  * @param text
  * @return byte[]
  * @throws Exception
  */
 public static byte[] encrypt(SecretKey key, String text) throws Exception {

  // 创建和初始化加密引擎
  Cipher cipher = Cipher.getInstance("DESede");
  cipher.init(Cipher.ENCRYPT_MODE, key);

  // 创建特殊的输出流
  // CipherOutputStream cos=new CipherOutputStream();
  byte[] buffer = text.getBytes();
  byte[] bytes = cipher.doFinal(buffer);

  // 安全起见,清除内存中的普通文本
  java.util.Arrays.fill(buffer, (byte) 0);

  return bytes;

 }

 /**
  * 解密
  *
  * @param key
  * @param bytes
  * @return String
  * @throws Exception
  */
 public static String decrypt(SecretKey key, byte[] bytes) throws Exception {

  // 初始化解密引擎
  Cipher cipher = Cipher.getInstance("DESede");
  cipher.init(Cipher.DECRYPT_MODE, key);
  // 解密

  byte[] buffer = cipher.doFinal(bytes);

  String text = new String(buffer);

  // 为保证安全,清除内存
  java.util.Arrays.fill(buffer, (byte) 0);

  return text;

 }

}
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
简要介绍<br>JAVA CLASS文件加密工具是一款专门为保护您的JAVA源代码而设计的软件。传统的JAVA代码保护方式通常是扰乱生成的CLASS文件,从而降低反编译生成的源代码的可读性;有的保护工具甚至能生成部分废代码(垃圾代码),使得反编译后的源码在重新编译时出现编译错误,不能直接生成CLASS文件。这种方法具有一定的效果,但是不能彻底保护您的JAVA源代码。 <br><br>JAVA CLASS文件加密工具对CLASS文件进行加密保护,加密密钥高达256位(bit,即:32字节),并采用多重加密的算法,既安全又高效。加密后的CLASS文件不可能被破解;反编译工具对加密后的CLASS文件无能为力,根本就不能处理! <br><br>运行方式<br>运行时,加密后的CLASS文件要能正常加载,需要使用我们提供的动态库hidea.dll。执行java时带上参数<br>-agentlib:<动态库文件所在路径>\hidea<br>注意:不要加文件后缀.dll,直接使用文件的名字部分(classloader)!<br><br>举例说明:例如,本加密工具安装在c:\hideasoft\java_protect,执行加密后的CLASS文件的命令行如下:<br>java -agentlib:c:\hideasoft\java_protect\hidea <您的CLASS类及参数><br>应用场合<br>独立的应用程序(Application,自定义main方法),运行java时,带上参数-agentlib:<所在路径>\hidea <br>Tomcat等JAVA Web Server,修改启动脚本,把执行java的命令行加上参数-agentlib:<所在路径>\hidea <br>JBOSS等JAVA Application Server(应用服务器),修改启动脚本,把执行java的命令行加上参数-agentlib:<所在路径>\hidea <br>适用环境操作系统:Windows 98/2000/XP 等Windows系统 <br>JDK:1.5.0及以上版本

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值