攻防世界 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 即可。

相关推荐
志栋智能12 小时前
超自动化安全:构建智能安全运营的核心引擎
大数据·运维·服务器·数据库·安全·自动化·产品运营
星幻元宇VR13 小时前
VR航空航天科普设备【VR时空直升机】
科技·学习·安全·生活·vr
weixin_5142531814 小时前
428-uitars tmux
安全·web安全
KKKlucifer18 小时前
日志审计与行为分析在安全服务中的应用实践
网络·人工智能·安全
ykjhr_3d20 小时前
vr电力安全培训系统有哪些
安全·vr·华锐视点
枷锁—sha20 小时前
【CTFshow-pwn系列】03_栈溢出【pwn 073】详解:静态编译下的自动化 ROP 链构建
网络·汇编·笔记·安全·网络安全·自动化
VBsemi-专注于MOSFET研发定制21 小时前
面向高可靠与能效需求的安全存储系统功率器件选型策略与适配手册
安全
xixixi7777721 小时前
AI安全周记:AI驱动攻击占比50%、PQC国标落地、ShinyHunters连环袭击——面对1:25的攻防成本鸿沟,防守方还能撑多久?
人工智能·安全·ai·大模型·aigc·量子计算·供应链
智擎软件测评小祺21 小时前
什么是非功能检测?筑牢软件性能与安全的基石
功能测试·安全·检测·cma·第三方检测·cnas·非功能检测
jinanwuhuaguo21 小时前
OpenClaw执行奇点——因果链折叠与责任悬置的时间哲学(第十九篇)
前端·人工智能·安全·重构·openclaw