Java加密解密 - 自定义类加载器的操纵[Java编程]
本文“Java加密解密 - 自定义类加载器的操纵[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
JAVA是注释履行的语言,关于差别的操作平台都有呼应的JVM对字节码文件举行注释履行.而这个字节码文件,也就是我们平常所看到的每一个.class文件.这是我们大家都知道的常识,也就是由.java文件,经过编译器编译,变成JVM所能注释的.class文件.而这个历程,在目前公开的网络技术中,操纵一个反编译器,任何人都可以很简单的获得它的源文件.这关于很多人来说是不但愿看到的.关于加密解密技术,我懂的不多,有些可以操纵某种技术“模糊”JAVA类文件.这样可以使反编译的难度增添.但预计反编译器的技术水平也在不断晋升,招致这种办法层层受阻.别的还有很多其他的技术也可以实现对JAVA文件的加密解密.我目前所想要研究的,就是此中的一种.JAVA的机动性使反编译变得简单,同时,也让我们的加密解密的办法变得机动.操纵自定义的CLASSLOADER.
JAVA中的每一个类都是通过类加载器加载到内存中的.关于类加载器的工作流程以下表示:
1.searchfile()
找到我所要加载的类文件.(抛除JAR包的概念,目前只是要加载一个.class文件)
2.loadDataClass()
读取这个类文件的字节码.
3.difineClass()
加载类文件.(加载的历程其实很复杂,我们目前先不研究它.)从这个历程中我们能很清楚的发现,自定义的类加载可以很轻松的掌握每个类文件的加载历程.这样在第二步(loadDataClass)和第三步(difineClass)之间,我们将会有自己的空间机动的掌握这个历程.我们加密解密的技术就利用到这里.加密解密 JAVA加密解密的技术有很多.JAVA自己供应了杰出的类库对各种算法举行支持.关于采取哪类算法,网络上说法不一.下面用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();
}
}
}
以上是“Java加密解密 - 自定义类加载器的操纵[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |