bugku-逆向-Timer(阿里CTF)(我的第一个Android逆向)

本文通过使用jeb反编译Android应用,聚焦于MainActivity,发现flag输出逻辑。分析代码发现,当beg(当前时间+200000)小于now(程序运行时间)时,flag会被设置。模拟程序运行200000秒后的k值,然后修改反编译后的代码,使if判断条件利于获取flag。最后在模拟器中运行,成功拿到flag。
摘要由CSDN通过智能技术生成

使用jeb进行反编译成java代码,MainActivity为程序的入口,首先对这个部分进行查看,找到了输出flag的地方。

在这里插入图片描述
对程序进行分析
this.beg = (((int)(System.currentTimeMillis() / 1000))) + 200000;beg为一个定值,在上面代码的run()函数中,k是可以变化的

MainActivity.this.t = System.currentTimeMillis();
MainActivity.this.now = ((int)(MainActivity.this.t / 1000));
给出了now的赋值,从程序的运行来看,beg在now初始赋值后应该比now大了200000,now代表的是程序运行的时间,当now变化了200000的时候,也就是说beg小于now的时候,会进入设置flag的地方。

也就是说,程序一开始k是变化的,flag的值并没被设置,只有当beg==now的时候,flag会被设置并显示,然后到下面k可能还会变化,那么这个被设定的初始flag可能就是我们要拿到的flag了。

直接根据k的变化部分的函数进行模拟,算出进行了200000s之后的k值:

public class test{
   
	
	public static boolean is2(int arg4) {
   
        boolean v1 = true;
        if
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值