angr - A+B problem

python - angr(github):

是一个符号执行工具,可以很好的辅助逆向和漏洞挖掘等二进制工作

一般可以自己先手动分析程序,得到许多限制条件,然后利用符号执行的方法遍历整个数据流和代码流,从而得到想要的结果~举例如下:

 

自己的代码:

#include<stdio.h>

int main(){
    int a,b;
    printf("Please Enter two Number A & B:\n");
    scanf("%d%d",&a,&b);
    if (a + b == 4 && a - b == 2)
        printf("Yes!\n");
    else
        printf("No!\n");
    return 0;
}

然后运用angr解题:

>>> p = angr.Project('./mycode')
>>> state = p.factory.entry_state()
>>> x = state.solver.BVS("x", 64)
>>> y = state.solver.BVS("y", 64)
>>> state.solver.add(x + y == 4)
[<Bool (x_0_64 + y_1_64) == 0x4>]
>>> state.solver.add(x - y == 2)
[<Bool (x_0_64 - y_1_64) == 0x2>]
>>> state.solver.eval(x)
3L
>>> state.solver.eval(y)
1L

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值