本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

暂无数据

使用 ASM [JAVA] 重新排列 GOTO [关闭]

发布于2024-11-10 15:16     阅读(1066)     评论(0)     点赞(28)     收藏(5)


我正在查看一个模糊处理的应用程序,该应用程序似乎有很多 GOTO,我想重新排列或删除它们

问题是,我该如何做这件事?

for(final MethodNode mn : classNode.methods) {
            final BIF is = new BIF(mn); //BIF is my bytecode instruction finder
            AbstractInsnNode ain;
            while ((ain = is.next()) != null) {
                if (ain instanceof JumpInsnNode && ain.getOpcode() == GOTO) {
                    final JumpInsnNode jump = (JumpInsnNode) ain;
                    mn.instructions.remove(jump);
                    removed++;
                }
            }
        }

所以我尝试把它们全部删除,但似乎不起作用,而且我不知道如何重新排列它们


解决方案


我认为你无法轻松解决这个问题,它看起来是一种相当激进的混淆机制。你可以尝试取消 goto,通过对 goto 跳转之间的块进行碎片整理来线性化代码。但是,有些 goto 是合法的流控制跳转,所以你需要一种方法来检测它。这看起来是一个真正的挑战,会占用你很多时间。但是,也许这个挑战足够吸引人,值得你继续前进 :)



所属网站分类: 技术文章 > 问答

作者:黑洞官方问答小能手

链接:http://www.javaheidong.com/blog/article/692866/0553f116b48d49a47c87/

来源:java黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

28 0
收藏该文
已收藏

评论内容:(最多支持255个字符)