ASM:如何找到ALOAD中包含的对象的类型
创始人
2024-11-11 12:01:23
0

在ASM中,可以通过以下步骤找到ALOAD指令中加载的对象的类型:

  1. 创建一个ClassVisitor类的子类,重写visitMethod方法。该方法会在访问每个方法时被调用。
class AloadClassVisitor extends ClassVisitor {
    public AloadClassVisitor(ClassVisitor cv) {
        super(ASM7, cv);
    }

    @Override
    public MethodVisitor visitMethod(int access, String name, String descriptor, String signature, String[] exceptions) {
        MethodVisitor mv = super.visitMethod(access, name, descriptor, signature, exceptions);

        // 在方法中插入代码
        return new AloadMethodVisitor(mv);
    }
}
  1. 创建一个MethodVisitor类的子类,重写visitVarInsn方法。该方法会在访问每个指令时被调用。
class AloadMethodVisitor extends MethodVisitor {
    public AloadMethodVisitor(MethodVisitor mv) {
        super(ASM7, mv);
    }

    @Override
    public void visitVarInsn(int opcode, int var) {
        if (opcode == ALOAD) {
            System.out.println("ALOAD " + var);
            
            // 获取局部变量表中的加载对象的类型
            super.visitVarInsn(ALOAD, var);
            super.visitMethodInsn(INVOKEVIRTUAL, "java/lang/Object", "getClass", "()Ljava/lang/Class;", false);
            super.visitMethodInsn(INVOKEVIRTUAL, "java/lang/Class", "getName", "()Ljava/lang/String;", false);
            super.visitLdcInsn("ALOAD Type: ");
            super.visitInsn(CONCAT);
            super.visitMethodInsn(INVOKESTATIC, "java/lang/String", "valueOf", "(Ljava/lang/Object;)Ljava/lang/String;", false);
            super.visitMethodInsn(INVOKESTATIC, "java/lang/System", "out", "Ljava/io/PrintStream;", false);
            super.visitInsn(SWAP);
            super.visitMethodInsn(INVOKEVIRTUAL, "java/io/PrintStream", "println", "(Ljava/lang/String;)V", false);
        }

        super.visitVarInsn(opcode, var);
    }
}
  1. 在访问每个ALOAD指令时,获取局部变量表中加载对象的类型,并输出。
public static void main(String[] args) throws IOException {
    ClassReader cr = new ClassReader("YourClass");
    ClassWriter cw = new ClassWriter(cr, ClassWriter.COMPUTE_MAXS);
    ClassVisitor cv = new AloadClassVisitor(cw);
    cr.accept(cv, ClassReader.EXPAND_FRAMES);

    byte[] transformed = cw.toByteArray();

    // 将转换后的字节码写回到类文件
    try (FileOutputStream fos = new FileOutputStream("YourClass.class")) {
        fos.write(transformed);
    } catch (IOException e) {
        e.printStackTrace();
    }
}

以上代码会在每个ALOAD指令处输出加载对象的类型。你可以根据自己的需要进行进一步处理,比如将类型存储到List中进行分析。

相关内容

热门资讯

3分钟技法!嘟咪互动修改器(外... 3分钟技法!嘟咪互动修改器(外挂)本来一直都是有辅助攻略(哔哩哔哩)1、玩家可以在嘟咪互动修改器线上...
第2分钟课程!新道游智能辅助器... 第2分钟课程!新道游智能辅助器(外挂)一直是真的有辅助方法(哔哩哔哩)1、实时新道游智能辅助器透视辅...
第四分钟总结!潮友会app下载... 第四分钟总结!潮友会app下载安卓(外挂)原来一直都是有辅助方法(哔哩哔哩)1、完成潮友会app下载...
3分钟课程!同城游辅助软件(外... 3分钟课程!同城游辅助软件(外挂)切实一直都是有辅助技巧(哔哩哔哩)同城游辅助软件能透视中分为三种模...
九分钟方式!兴动休闲辅助(外挂... 九分钟方式!兴动休闲辅助(外挂)一直是真的有辅助方法(哔哩哔哩)1、金币登录送、破产送、升级送、活动...
第三分钟诀窍!今日长牌辅助(外... 第三分钟诀窍!今日长牌辅助(外挂)总是真的是有辅助技巧(哔哩哔哩)1、下载好今日长牌辅助脚本下载之后...
7分钟秘籍!中至辅助(外挂)本... 7分钟秘籍!中至辅助(外挂)本来真的有辅助app(哔哩哔哩)1、实时中至辅助透视辅助更新:用户可以随...
1分钟手册!财神十三章张助安装... 1分钟手册!财神十三章张助安装包(外挂)一贯有辅助脚本(哔哩哔哩)1、进入到财神十三章张助安装包是否...
八分钟诀窍!如何下载并安装胡乐... 八分钟诀窍!如何下载并安装胡乐辅助脚本(外挂)真是有辅助脚本(哔哩哔哩)1、全新机制【如何下载并安装...
第6分钟方针!决战辅助(外挂)... 第6分钟方针!决战辅助(外挂)一贯真的是有辅助软件(哔哩哔哩)1)决战辅助有没有挂:进一步探索决战辅...