[原创]IDA搜索立即数
2022-6-23 15:19 8271
最近在分析一些应用的错误码处理,想通过接口返回的错误码找到应用中的处理方式
1.IDA直接搜索立即数
大多数情况下,立即数的搜索都可以直接使用ALT+B进行立即数的搜索
例如:
上图这种情况
直接ALT+B
即可得到结果
在搜索的时候记得把汇编视图的滚动条拉到最顶
2.IDApy脚本搜索立即数
在下图这种情况下
一个立即数被拆分成两个立即数位移后相加的情况下,可以采用idapython脚本进行搜索
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
idc.GetOpType(addr, index)函数用来判断指令类型, 返回值为5则为立即数
idc.GetOperandValue(addr, index)函数用来获取指令的值
上面的脚本遇上
这种伪指令就歇菜了 这里去读这个=XXX的值只能读到他的地址 其实可以读地址再去读地址对应的值,不过ALT+B能解决我就懒得写脚本找了
关于idapython的教程可以看这个
IDAPython基础教程
|
|
---|---|
ALT+I |
|
kakasasa ALT+I 感谢大佬指点 |
|
你这个脚本是在比较老的IDA中测的吧,现在这两个函数是 idc.get_operand_type |
|
scz 你这个脚本是在比较老的IDA中测的吧,现在这两个函数是 idc.get_operand_type idc.get_operand_value 是的 在7.0的ida中跑的 |
|
搜索立即数推荐用 FindFunc 插件,支持多个特征立即数组成规则 |
|
返回