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

相关推荐
光殿14 小时前
性能测试
测试
LH_R17 小时前
OneTerm开源堡垒机实战(三):功能扩展与效率提升
运维·后端·安全
你的人类朋友1 天前
什么是API签名?
前端·后端·安全
深盾安全1 天前
ProGuard混淆在Android程序中的应用
安全
CYRUS_STUDIO2 天前
利用 Linux 信号机制(SIGTRAP)实现 Android 下的反调试
android·安全·逆向
白帽黑客沐瑶2 天前
【网络安全就业】信息安全专业的就业前景(非常详细)零基础入门到精通,收藏这篇就够了
网络·安全·web安全·计算机·程序员·编程·网络安全就业
深盾安全2 天前
符号执行技术实践-求解程序密码
安全
贾维思基2 天前
被监管警告后,我连夜给系统上了“双保险”!
安全
00后程序员张2 天前
iOS App 混淆与加固对比 源码混淆与ipa文件混淆的区别、iOS代码保护与应用安全场景最佳实践
android·安全·ios·小程序·uni-app·iphone·webview
Devil枫2 天前
鸿蒙深链落地实战:从安全解析到异常兜底的全链路设计
安全·华为·harmonyos