文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

吾爱2023新年红包题第四题

2023-08-16 17:37

关注

吾爱论坛2023年春节红包安卓题,随便玩一玩;

https://www.52pojie.cn/thread-1738015-1-1.html
在这里插入图片描述
第四题:https://www.52pojie.cn/home.php?mod=task&do=view&id=23

首先我们下载后,打开apk看下界面提示情况;

在这里插入图片描述

看界面是用到了, 你的吾爱uid 以及计算出来的flag 进行效验;

在这里插入图片描述

先定位到方法,我们又看到,用到了MD5加密和 base64;
在这里插入图片描述
还是先看方法逻辑吧:

在这里插入图片描述
obj也就是第一个输入框的内容,那不就是uid吗

  String obj = StringsKt.trim((CharSequence) editText.getText().toString()).toString();

后面这个就是第二个输入框,flag

StringsKt.trim((CharSequence) editText2.getText().toString()).toString())

进入a.m25B方法:

在这里插入图片描述
uid -> str ->encode ->c.cipher(mD5Utils.MD5(base64Utils.encodeToString(bytes)), 5)

flag -> str2 -> substring

显然这个方法是 返回一个 bool类型结果,那就是 true | false;

又看到最后确实是比对这两个值:

在这里插入图片描述
分析其逻辑,我们只要知道,c.cipher(mD5Utils.MD5(base64Utils.encodeToString(bytes)), 5)

就是比对的结果;

分析运算逻辑:

将 uid + “Wuaipojie2023” 进行 encode 方法运算:

    public static String encode(String str) {        int length = str.length();        char[] cArr = new char[length];        int i = length - 1;        while (i >= 0) {            int i2 = i - 1;            cArr[i] = (char) (str.charAt(i) ^ '5');            if (i2 < 0) {                break;            }            i = i2 - 1;            cArr[i2] = (char) (str.charAt(i2) ^ '2');        }        return new String(cArr);    }

后转bytes进行base64编码;
====这里的base64也都是标准的,无魔改,无改码表;

然后将base64之后进行md5加密,加密后得出32位值,再用 cipher 做运算;

public final String cipher(String str, int i) {        Intrinsics.checkNotNullParameter(str, "str");        StringBuilder sb = new StringBuilder();        int length = str.length();        for (int i2 = 0; i2 < length; i2++) {            if (Intrinsics.compare((int) str.charAt(i2), 65) >= 0 && Intrinsics.compare((int) str.charAt(i2), 90) <= 0) {                sb.append(cipher(str.charAt(i2), i));            } else if (Intrinsics.compare((int) str.charAt(i2), 97) < 0 || Intrinsics.compare((int) str.charAt(i2), 122) > 0) {                sb.append(str.charAt(i2));            } else {                sb.append(cipher(str.charAt(i2), i));            }        }        String sb2 = sb.toString();        Intrinsics.checkNotNullExpressionValue(sb2, "sb.toString()");        return sb2;    }

运算之后:

在这里插入图片描述

那就是 cipher之后:h8203kj86395hf8677jgj599ki82g0i9;

在这里插入图片描述

那么格式就是 flag{cipher之后的值了} ;

在这里插入图片描述

来源地址:https://blog.csdn.net/weixin_38927522/article/details/128816834

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯