`
coreoak
  • 浏览: 65309 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

java加密技术收集

阅读更多

在chinaitlab上面找到关于java加密技术的文章, 摘抄下来, 日后好好学习,链接地址:http://java.chinaitlab.com/base/719984_2.html

 最近在研究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();
        }


    }

}

 

第二步,对我们所要进行加密的类文件进行加密。

    比如我有一个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面试题收集集锦

    面试题集锦还包括了对J2ME、EJB生命周期、连接池原理、分页、线程、文件加密、软件开发生命周期、网络协议、GUI设计、事件处理模式等多个主题的考察,这些都是Java程序员应具备的知识点。通过深入理解和实践这些概念...

    java zip加密压缩

    在Java编程语言中,我们可以利用...以上就是关于"java zip加密压缩"的知识点,包括CSV文件的处理、ZIP文件的压缩、AES加密的原理及整合这些技术来实现文件的加密压缩。希望这些信息对你理解和实现相关功能有所帮助。

    Java加密解密方法大全

    ### Java加密解密方法大全 #### 1. 加密概述 **1.1 加密的应用** 随着信息技术的发展,数据安全成为越来越重要的问题。加密技术作为一种有效的保护数据安全的方法,在各个领域得到了广泛的应用。例如,在互联网...

    Java pdf资源收集

    Java PDF资源收集是一个针对Java开发者精心整理的资料合集,主要涵盖了Java开发中的各种主题,尤其是与PDF处理相关的知识。PDF(Portable Document Format)是一种广泛使用的文档格式,它能够跨平台保留原始文档的...

    Java实现加密解密

    Java实现加密解密主要涉及到的是信息安全领域中的数据保护技术。DES(Data Encryption Standard)是一种经典的对称加密算法,用于保护数据的隐私性和安全性。在Java中,我们可以使用Java Cryptography Extension ...

    Java高新技术

    2. **内存管理**:Java的垃圾收集机制(Garbage Collection, GC)是其一大特点,它自动管理内存,避免了内存泄漏。了解不同类型的GC算法(如Serial、Parallel、CMS、G1、ZGC、Shenandoah)及其应用场景,对于优化...

    java 加密解密

    根据给定的文件信息,以下是对“java加密解密”这一主题的知识点详细解析: ### Java中的加密解密 在IT行业中,加密解密技术是确保数据安全的关键环节,尤其是在互联网时代,数据传输的安全性变得尤为重要。Java...

    信息收集系统客户端和服务器 CS架构(android+java后台).zip

    本文将深入探讨一种基于客户端-服务器(Client-Server,简称CS)架构的信息收集系统,该系统采用Android作为客户端平台,Java作为后台服务器端的技术栈,旨在提供高效、安全的数据交互解决方案。 首先,我们要理解...

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

    ### Java 加密解密之对称加密算法AES #### 高级加密标准(AES) AES是一种广泛使用的对称加密算法,被美国联邦政府采纳作为官方的加密标准来替代早期的DES算法。它由比利时密码学家Joan Daemen和Vincent Rijmen...

    Java核心技术·卷2 高级特性(第10版英文版)

    高级平台安全特性:讲解Java平台的安全模型,包括加密、授权、数字签名等。 注解(Annotations):探讨注解的使用和自定义,以及如何通过注解简化代码。 分布式对象:涉及远程方法调用(RMI)和其他分布式对象技术...

    《Java核心技术 卷2 高级特性 原书第8版》 PDF+高清+影印+全书签.rar

    10. **Java安全**:Java的安全模型是其一大特色,书中涵盖了安全管理器、权限、证书和加密等内容,有助于开发安全的应用程序。 通过阅读《Java核心技术 卷2 高级特性 原书第8版》,读者不仅可以掌握Java的高级特性...

    Java卡虚拟机的安全攻击技术及防御技术研究.pdf

    这些防御措施可能包括但不限于:代码签名验证、访问控制、数据加密、异常处理、垃圾收集机制、实时监控等。通过在Java卡平台实施这些防御措施,可以有效地提高其安全性能,防止潜在的攻击者对Java卡进行破坏。 实验...

    Java高新技术7

    12. **Java安全**:Java安全模型包括安全管理器、权限、证书和加密等,理解这些概念对于构建安全的应用程序至关重要。 13. **JMX(Java Management Extensions)**:JMX用于管理系统资源,如监控和管理Java应用程序...

    c语言对java的class文件进行加密解密

    总的来说,这个技术组合涉及到多层安全措施,从代码的存储安全(加密)到运行时的保护(jvmti和jvmagent),再到跨语言的交互(JNI调用DLL),全方位地提升了Java应用程序的安全性。然而,这种做法也增加了系统的...

    基于java Instrumentation技术的数据采集探针验证.pdf

    基于抓包技术的监控尽管非侵入、不依赖于系统实现语言,但它具有开发难度大、数据丢失概率大和无法分析加密数据等缺点。而通过修改原系统的源码来监控系统的做法同样存在问题,因为这种方法并不适用于线上运行系统。...

    java课设[收集].pdf

    【知识点详解】 1. **Java程序设计基础**:该课设涵盖了...通过这个课设,学生不仅能够巩固Java编程基础,还能深入理解数据库连接、GUI设计和事件处理等实际应用技术,同时锻炼了软件开发的完整流程和团队协作能力。

    收集的java坐标转换WGS84、GCJ02B、BD09及纠偏

    总的来说,Java坐标转换是一个技术含量较高的领域,涉及到地理学、数学和编程等多个方面的知识。这两个文件提供了实现这些转换的代码,对于学习和实践坐标转换的开发者来说,是非常宝贵的资源。

    zabbix-java-gateway.tar.zip

    这对于那些基于Java技术栈的大型分布式系统来说,是确保系统健康运行不可或缺的工具。 1. **Java Gateway的工作原理** Zabbix Java Gateway作为一个独立的服务运行,通常配置在与Zabbix Server不同的主机上,以...

Global site tag (gtag.js) - Google Analytics