首页
社区
课程
招聘
[旧帖] [转帖]修改java字节码 0.00雪花
发表于: 2010-1-2 16:08 1884

[旧帖] [转帖]修改java字节码 0.00雪花

2010-1-2 16:08
1884
转贴来源不明。。。忘记了从哪里下载到的一个doc

有时候,我们在没有java源程序的情况下,想改变.CLASS文件的部分内容输出或者改变跳转流,怎么办呢?
  介绍2个java hacker的工具javassist 以及jclasslib。

下载javassist-3.1RC2和jclasslib_windows_3_0。

解压后,将2个JAR 加入classpath内。



原文件HelloWorld.java

package com.unmi;   
  
public class HelloWorld   
{   
    public static void main(String[] args)   
    {   
        System.out.println("Hello,gorld!");   
    }   
}  

想修改输出的”hello world”,用jclasslib.exe 检测可以看到



属于常量池的23。 如下代码就针对23 做调整。

package com.unmi;

import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;

import java.io.*;

import org.gjt.jclasslib.io.ClassFileWriter;
import org.gjt.jclasslib.structures.CPInfo;
import org.gjt.jclasslib.structures.ClassFile;
import org.gjt.jclasslib.structures.constants.ConstantStringInfo;
import org.gjt.jclasslib.structures.constants.ConstantUtf8Info;

public class JclasslibTest {
    public static void main(String[] args) throws Exception {
          {
              String filePath = "D:\\java_proj\\com\\unmi\\HelloWorld.class";
              FileInputStream fis = new FileInputStream(
                      filePath);

              DataInput di = new DataInputStream(fis);
              ClassFile cf = new ClassFile();
              cf.read(di);
              CPInfo[] infos = cf.getConstantPool();

              int count = infos.length;
              for (int i = 0; i < count; i++) {
                  if (infos[i] != null) {
                      System.out.print(i);
                      System.out.print(" = ");
                      System.out.print(infos[i].getVerbose());
                      System.out.print(" = ");
                      System.out.println(infos[i].getTagVerbose());
                      if(i == 23){
                            ConstantUtf8Info uInfo = (ConstantUtf8Info)infos[i];
                            uInfo.setString("china alibaba inc.com");
                           
                      }                       
                  }
              }
              cf.setConstantPool(infos);
              fis.close();
              File f = new File(filePath + "c");
              ClassFileWriter.writeToFile(f, cf);
        }
    }
}

D:\java_proj>javac -cp %CLASSPATH%;.  com/unmi/JclasslibTest.java

D:\java_proj>java   com.unmi.JclasslibTest
1 = com/unmi/HelloWorld = CONSTANT_Class_info
2 = com/unmi/HelloWorld = CONSTANT_Utf8_info
3 = java/lang/Object = CONSTANT_Class_info
4 = java/lang/Object = CONSTANT_Utf8_info
5 = <init> = CONSTANT_Utf8_info
6 = ()V = CONSTANT_Utf8_info
7 = Code = CONSTANT_Utf8_info
8 = java/lang/Object.<init> = CONSTANT_Methodref_info
9 = <init>()V = CONSTANT_NameAndType_info
10 = LineNumberTable = CONSTANT_Utf8_info
11 = LocalVariableTable = CONSTANT_Utf8_info
12 = this = CONSTANT_Utf8_info
13 = Lcom/unmi/HelloWorld; = CONSTANT_Utf8_info
14 = main = CONSTANT_Utf8_info
15 = ([Ljava/lang/String;)V = CONSTANT_Utf8_info
16 = java/lang/System.out = CONSTANT_Fieldref_info
17 = java/lang/System = CONSTANT_Class_info
18 = java/lang/System = CONSTANT_Utf8_info
19 = outLjava/io/PrintStream; = CONSTANT_NameAndType_info
20 = out = CONSTANT_Utf8_info
21 = Ljava/io/PrintStream; = CONSTANT_Utf8_info
22 = Hello,gorld! = CONSTANT_String_info
23 = Hello,gorld! = CONSTANT_Utf8_info
24 = java/io/PrintStream.println = CONSTANT_Methodref_info
25 = java/io/PrintStream = CONSTANT_Class_info
26 = java/io/PrintStream = CONSTANT_Utf8_info
27 = println(Ljava/lang/String;)V = CONSTANT_NameAndType_info
28 = println = CONSTANT_Utf8_info
29 = (Ljava/lang/String;)V = CONSTANT_Utf8_info
30 = args = CONSTANT_Utf8_info
31 = [Ljava/lang/String; = CONSTANT_Utf8_info
32 = SourceFile = CONSTANT_Utf8_info
33 = HelloWorld.java = CONSTANT_Utf8_info

更改生成的HelloWorld.classc 为HelloWorld.class

执行输出为
D:\java_proj>java com.unmi.HelloWorld
china alibaba inc.com

另外,也可以修改if 语句跳转



Jclasslib 观测到jvm op code 如下



现在想更改>= 为<,怎么办?
查询Opcode Mnemonics by Opcode

http://java.sun.com/docs/books/jvms/second_edition/html/Mnemonics.doc.html
并查到 >= 的操作码为 0xA1



所以只要用Ultraedit 修改 0xA1 为 0xA2 就可以了。
再次用jclasslib加载 .class 可以看到仅仅变更了比较的操作码


[招生]科锐逆向工程师培训(2024年11月15日实地,远程教学同时开班, 第51期)

上传的附件:
  • 1.jpg (79.64kb,320次下载)
  • 2.jpg (97.00kb,319次下载)
  • 3.jpg (53.54kb,320次下载)
  • 4.jpg (81.78kb,319次下载)
  • 5.jpg (246.09kb,323次下载)
  • 6.jpg (126.76kb,318次下载)
收藏
免费 0
支持
分享
最新回复 (5)
雪    币: 96
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
学习了,看来楼主是强人
2010-1-18 18:25
0
雪    币: 328
活跃值: (39)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
3
还可以,感觉已经深入到字节代码的级别了,你提到的这两个工具
应用也很广泛,在类文件修改、生成方面用的很多。

同时建议通过字节代码的阅读理解,进行更深的研究,比如混淆代码的回复等

希望Java破解的高手越来越多
2010-2-20 14:58
0
雪    币: 29
活跃值: (45)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
帖子写的很好,学习了。
2010-10-11 16:26
0
雪    币: 255
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
5
不错···学习了!
2010-10-11 17:36
0
雪    币: 265
活跃值: (56)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
6
楼主,写的不错,方法和技巧都很通俗,期待更好的作品
2011-5-1 09:38
0
游客
登录 | 注册 方可回帖
返回
//