xulrmb 发表于 2008-11-11 18:56

手动修改java class 文件

以前做的一个网站,最近发现其中一个类里面的sql语句有问题,所以想修改一下
在源码没有的环境下,我就想能不能直接修改class文件呢?
于是我用UltraEdit以16进制方式打开class文件,找到要修改的sql语句,直接删除了几个字节然后重新
写入内容,正当我暗自欢喜之时,发现这类根本加载不了,会报一个和常量池有关的错误。
看来不是想象那么简单,可能是修改后的文件过不了jvm的检查。
于是下载了一份Java 虚拟机规范研究了一下,终于理解了java class文件的格式
下面用一个简单的程序试验一下:
package test;
public class Class_Stardy {
public void s(){
String ss = "123";
System.out.println(ss);   
}
}
其中ss是一个已确定的字符串,这个字符串在编译的class文件中是以一个叫做
CONSTANT_Utf8_info的结构存储,这个结构的定义如下:
CONSTANT_Utf8_info{
u1 tag;//一字节 固定为1
u2 length;//二字节 存储的字符串长度
u1 bytes;//一字节存储的具体内容
}
存储的具体内容的长度要和预先设置的长度一样,所以直接修改字符串的具体内容是不行的
还要调整length的大小。OK,用UltraEdit打开编译好的class文件,如下图
http://s11.photo.store.qq.com/http_imgload.cgi?/rurl4_b=48a684e706b8a30b7d33cbe56e119c782e19c528877f39ee0541514f0ceaba0cc5d5bd3851fbcff9d86a9aa75222826b4bdfc01d6869ec606c440efc090ddfa820ae4db72a3b0d548000503015b1f7b8090bda45
其中0000009fh: 01 00 03 31 32 33   ; ..123就是一个CONSTANT_Utf8_info结构的内容
tag=01,length=3,31 32 33就是内容
如果想把ss内容改为1234 则length加1,内容后面加上34,保存就可以了
不用编译,哈哈

iptton 发表于 2008-11-11 19:45

LZ貌似很喜欢做这类事情。。
PS:介绍得更全面点或给点相应的资料地址就更好了..

xulrmb 发表于 2008-11-11 20:26

Java 虚拟机规范网上有很多中文版的下载的
页: [1]
查看完整版本: 手动修改java class 文件