攻防世界 XCTF 【Mobile】RememberOther 题解

正常下载附件,解压后,拖到 JADX-gui 中去反编译一下,然后保存到文件夹里去,用 IDEA 打开,方便我们编辑。

打开之后,观察一下 AndroidManifest.xml 里面都有什么。

也没啥值得说的东西,直接看 MainActivity 就行了

java 复制代码
    public void onCreate(Bundle savedInstanceState) {
        ...
        
        this.edit_userName = (EditText) findViewById(R.id.edit_username);
        this.edit_sn = (EditText) findViewById(R.id.edit_sn);
        this.btn_register = (Button) findViewById(R.id.button_register);
        this.btn_register.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                if (!MainActivity.this.checkSN(MainActivity.this.edit_userName.getText().toString().trim(), MainActivity.this.edit_sn.getText().toString().trim())) {
                    Toast.makeText(MainActivity.this, (int) R.string.unsuccessed, 0).show();
                    return;
                }
                Toast.makeText(MainActivity.this, (int) R.string.successed, 0).show();
                MainActivity.this.btn_register.setEnabled(false);
                MainActivity.this.setTitle(R.string.registered);
            }
        });
    }

代码很简单,获取 edit_userName 和 edit_sb 的值,然后放到 checkSN 函数里对比一下,如果错误就输出 unsuccessed 如果正确就显示 successed

简单看看 checkSN 函数的内容吧。

java 复制代码
    public boolean checkSN(String userName, String sn) {
        try {
            if (userName.length() == 0 && sn.length() == 0) {
                return true;
            }
            if (userName == null || userName.length() == 0) {
                return false;
            }
            if (sn == null || sn.length() != 16) {
                return false;
            }
            MessageDigest digest = MessageDigest.getInstance("MD5");
            digest.reset();
            digest.update(userName.getBytes());
            byte[] bytes = digest.digest();
            String hexstr = toHexString(bytes, BuildConfig.FLAVOR);
            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < hexstr.length(); i += 2) {
                sb.append(hexstr.charAt(i));
            }
            String userSN = sb.toString();
            return userSN.equalsIgnoreCase(sn);
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
            return false;
        }
    }

啊, 这,看第一个分支,如果 userName 和 sn 长度都是 0 ,那么直接就放回 true 了,这是第一种通过检测的方法。

继续往下看,就是将 userName 进行一次 MD5,然后再调用 toHexString 函数,然后进行对比即可,看一下 toHexString 函数的具体内容

java 复制代码
    private static String toHexString(byte[] bytes, String separator) {
        StringBuilder hexString = new StringBuilder();
        for (byte b : bytes) {
            String hex = Integer.toHexString(b & 255);
            if (hex.length() == 1) {
                hexString.append('0');
            }
            hexString.append(hex).append(separator);
        }
        return hexString.toString();
    }

就是经过了一个 b & 255 位运算而已

那么逻辑也很简单,直接复制代码然后稍微改改,调试一下,可以看到 admin 对应的注册码是 222275aa4840481c

填入用户名和注册码,发现确实可以通过验证,然后弹出提示:md5:b3241668ecbeb19921fdac5ac1aafa69, 当然按照前面说的,这里用户名和注册码都为空的时候也是可以通过验证的。

其实,阅读完代码,这里直接去 strings.xml 中也是可以直接看到 successed 对应的字符的

那么去解密一下 MD5

尴尬,还要购买,那去看看其他师傅的结果吧,解出来是 YOU_KNOW_ 这里想起来,下载题目附件后解压后还附带了一个 docx 文档

文档里写的不懂安卓,那么看起来 YOU_KNOW_ 好像还缺了点什么,那么大概是说 你懂安卓了呗,所以猜测正确的flag 应该是 YOU_KNOW_ANDROID, 提交这个 flag 即可。

相关推荐
Ftrans6 小时前
【分享】文件摆渡系统适配医疗场景:安全与效率兼得
大数据·运维·安全
筑梦之月6 小时前
网络安全职业指南:探索网络安全领域的各种角色
安全·web安全
我认为可以!6 小时前
CSRF 攻击原理与实验测试(附可运行测试案例)
安全·csrf
Raners_6 小时前
【Java代码审计(2)】MyBatis XML 注入审计
xml·java·安全·网络安全·mybatis
Synfuture阳途7 小时前
终端安全管理系统为什么需要使用,企业需要的桌面管理软件
网络·安全
时间海里的溺水者8 小时前
应用软件格式渗透 利用word去渗透(MS10-087)
安全·web安全
程序员二黑9 小时前
零基础10分钟配好自动化环境!保姆级教程(Win/Mac双版)附避坑工具包
面试·程序员·测试
HCIE考证研究所10 小时前
考完数通,能转云计算/安全方向吗?转型路径与拓展路线分析
网络·安全·华为·云计算·网络工程师·华为认证·数通
snow@li12 小时前
AI问答-测试:理解冒烟测试(Smoke Testing)
测试·冒烟测试
Xudde.13 小时前
解决了困扰我的upload靶场无法解析phtml等后缀的问题
学习·安全·php