RememberOther

RememberOther
下载是个压缩包,里面有个APK和word文档
word文档:(先放着)
在这里插入图片描述
APK拖进模拟器,输入错误显示无效用户名或注册码
在这里插入图片描述
JEB分析MainActivity,其中onCreate方法中将edit_userNameedit_sn调用checkSN函数

    public void onCreate(Bundle arg3) {
        super.onCreate(arg3);
        this.setContentView(0x7F030000);
        this.setTitle(0x7F05000A);
        this.edit_userName = this.findViewById(0x7F080001);
        this.edit_sn = this.findViewById(0x7F080002);
        this.btn_register = this.findViewById(0x7F080003);
        this.btn_register.setOnClickListener(new View$OnClickListener() {
            public void onClick(View arg5) {
                if(!MainActivity.this.`checkSN`(MainActivity.this.edit_userName.getText().toString().trim(), MainActivity.this.edit_sn.getText().toString().trim())) {
                    Toast.makeText(MainActivity.this, 0x7F05000B, 0).show();
                }
                else {
                    Toast.makeText(MainActivity.this, 0x7F050008, 0).show();
                    MainActivity.this.btn_register.setEnabled(false);
                    MainActivity.this.setTitle(0x7F050006);
                }
            }
        });
    }

查看checkSN函数:如果注册码和用户名都显示空,则返回false,接着调用MD5算法,返回16进制字符串,将奇数位上的字符组成字符串与注册码进行比较。。

  private boolean checkSN(String arg12, String arg13) {
        boolean v7 = true;
        try {
            if(arg12.length() == 0 && arg13.length() == 0) {
                return v7;
            }

            if(arg12 == null || arg12.length() == 0) {
                return false;
            }

            if(arg13 == null || arg13.length() != 16) {
                return false;
            }

            MessageDigest v1 = MessageDigest.getInstance("MD5");
            v1.reset();
            v1.update(arg12.getBytes());
            String v3 = MainActivity.toHexString(v1.digest(), "");
            StringBuilder v5 = new StringBuilder();
            int v4;
            for(v4 = 0; v4 < v3.length(); v4 += 2) {
                v5.append(v3.charAt(v4));
            }

            if(v5.toString().equalsIgnoreCase(arg13)) {
                return v7;
            }
        }
        catch(NoSuchAlgorithmException v2) {
            goto label_41;
        }

        return false;
    label_41:
        v2.printStackTrace();
        return false;
    }

不知道是哪个调用了MD5算法,就将用户名和注册码都为空尝试一下
结果跳出了md5:b3241668ecbeb19921fdac5ac1aafa69
也可以直接在AndroidKiller中搜索MD5查找到字符串
在这里插入图片描述
MD5解密链接
在这里插入图片描述
输入flag不对,要结合word文档里的不懂安卓,所以最终flag{YOU_KNOW_ANDROID}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值