当前位置:七道奇文章资讯编程技术Java编程
日期:2011-03-22 16:16:00  来源:本站整理

JAVA加密解密:自定义类加载器操纵[Java编程]

赞助商链接



  本文“JAVA加密解密:自定义类加载器操纵[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
近来在研究JAVA CLASS LOADING技术,已实现了一个自定义的加载器.对目前自定义加载器的利用,还在探究中.下面是自定义的CLASSLOADER在JAVA加密解密方面的一些研究.

JAVA安全

JAVA是注释履行的语言,关于差别的操作平台都有呼应的JVM对字节码文件举行注释履行.而这个字节码文件,也就是我们平常所看到的每一个.class文件.

这是我们大家都知道的常识,也就是由.java文件,经过编译器编译,变成JVM所能注释的.class文件.

而这个历程,在目前公开的网络技术中,操纵一个反编译器,任何人都可以很简单的获得它的源文件.这关于很多人来说是不但愿看到的.

关于加密解密技术,我懂的不多,有些可以操纵某种技术“模糊”JAVA类文件.这样可以使反编译的难度增添.但预计反编译器的技术水平也在不断晋升,招致这种办法层层受阻.别的还有很多其他的技术也可以实现对JAVA文件的加密解密.我目前所想要研究的,就是此中的一种.

JAVA的机动性使反编译变得简单,同时,也让我们的加密解密的办法变得机动.

操纵自定义的CLASSLOADER

参照:http://www.blogjava.net/realsmy/archive/2007/04/18/111582.html

JAVA中的每一个类都是通过类加载器加载到内存中的.关于类加载器的工作流程以下表示:
1.searchfile()
找到我所要加载的类文件.(抛除JAR包的概念,目前只是要加载一个.class文件)
2.loadDataClass()
读取这个类文件的字节码.
3.difineClass()
加载类文件.(加载的历程其实很复杂,我们目前先不研究它.)

从这个历程中我们能很清楚的发现,自定义的类加载可以很轻松的掌握每个类文件的加载历程.这样在第二步(loadDataClass)和第三步(difineClass)之间,我们将会有自己的空间机动的掌握这个历程.

我们加密解密的技术就利用到这里.

加密解密

JAVA加密解密的技术有很多.JAVA自己供应了杰出的类库对各种算法举行支持.关于采取哪类算法,网络上说法不一,自己去GOOGLE一下吧.

下面用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编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • 利用Javascript实现网页水印(非图片水印)
  • Java开辟环境的搭建
  • Ubuntu java安装与配置
  • 办理Ubuntu 10.04 Firefox3.6 Java浏览器插件不工作的问
  • Ubuntu重装后Java环境的设置
  • Sun Java进入Ubuntu 10.10软件中央
  • Ubuntu 10.10配置Java开辟环境
  • 在Ubuntu 10.10中配置Java环境变量的办法
  • Ubuntu下Java环境的搭建
  • Ubuntu 10.04 下安装 Java, JRE
  • Ubuntu 10.04下的搭建SUN JAVA开辟环境
  • Ubuntu 12.04安装java7
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .