理清程序的逻辑后,采用最简单的办法控制程序的执行路径——修改指令。
首先,通过菜单栏中Options/General/Disassembly/Number of opcode bytes设置IDA使其显示指令的机器码。
一般修改为16

jnz的机器码为75,只需将其改为jz的机器码74。修改方法:Edit/Patch program/Change byte
修改完后Edit/Patch program/Apply patches to input file保存修改后的文件,运行便能得到flag
结束。
题外话:通过“[*] You rolled a one! Very nice!”等提示信息找到其他几处判断语句,使用相同的方法修改机器码。但是有两处为near jump,jnz的机器码为0F 85,将其修改为0F 84即可。
修改完后Edit/Patch program/Apply patches to input file保存修改后的文件,运行便能得到flag。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/234648.html原文链接:https://javaforall.cn