首页 > 其他分享 >[羊城杯 2020]easyre

[羊城杯 2020]easyre

时间:2023-05-14 10:55:58浏览次数:34  
标签:26 加密 string int Des flag easyre 羊城 2020

查壳:

64位,没什么信息,进IDA:

能看到有三个加密,都通过的话就是正确的flag,也给了我们最后的密文"EmBmP5Pmn7QcPU4gLYKv5QcMmB3PWHcP5YkPq3=cT6QckkPckoRG"

由于我们是要返回flag那么我倒回去看加密,先看encode_three:

逻辑加密,再看encode_two:

打乱字符串,再看encode_one:

base64加密?不确定,看看码表:

base64加密妥了。

总结下思路,对flag进行base64的加密后,进行字符串的打乱,最后逻辑加密。(这逻辑加密有点绕,直接考虑爆破了,不想逆推了都)

上脚本:

int main(){
    string Des = "EmBmP5Pmn7QcPU4gLYKv5QcMmB3PWHcP5YkPq3=cT6QckkPckoRG";
    string flag = "";
    for (int i = 0; i < Des.size(); ++i ){
        for (int j = 32; j <= 127; j++) {
            if ( j > 90 || j <= 64)
            {
                if ( j <= 96 || j > 122 )
                {
                    if (j <=47 || j > 57 ) {
                        if (j == Des[i])flag += char(j);
                    }
                    else {
                        if ((j - 48 + 3) % 10 + 48 == Des[i])
                            flag += char(j);
                    }
                }
                else
                {
                    if((j - 97 + 3) % 26 + 97 == Des[i])
                    flag += char(j);
                }
            }
            else
            {
                if((j - 65 + 3) % 26 + 65 == Des[i])
                flag += char(j);
            }
        }
    }
    cout << flag << endl;
    return 0;
}

得到BjYjM2Mjk4NzMR1dIVHs2NzJjY0MTEzM2VhMn0=zQ3NzhhMzhlOD。

打乱顺序那个,我看了其他大佬的文章,都是利用python来写的(不得不说python提供的[]也特别优秀,这里我就不用那玩意了,我感觉我解释不清楚那玩意)上我自己的脚本:

我们再来看看

第一个strncpy是将al(也就是原始flag经过加密后的字符串)下标为26到最后一个字符的所有字符复制到a3下标为0到最后一个字符

第二个strncpy是将al(也就是原始flag经过加密后的字符串)下标为0到最后一个字符的所有字符复制到a3下标为13到最后一个字符(这里不会出现越界的问题,是保证了同等长度了)

也就说a3 0~12的字符没有被覆盖,而13到最后的字符重新被覆盖了。可以利用这个特点,去还原原本的字符串:

int main(){
    string flag = "BjYjM2Mjk4NzMR1dIVHs2NzJjY0MTEzM2VhMn0=zQ3NzhhMzhlOD";
    string flag1 = "";
    string flag2 = "";
    string flag3 = "";
    string flag4 = "";
    int cn = 0;
    for (int i = 13; i < 26; i++) {
        flag1 += flag[i];
    }
    for (int i = 39; i < flag.size(); i++) {
        flag2 += flag[i];
    }
    for (int i = 0; i < 13; i++) {
        flag3 += flag[i];
    }
    for (int i = 26; i < 26+13; i++) {
        flag4 += flag[i];
    }
    string ans = flag1+flag2+flag3+flag4;
    cout << ans << endl;
    return 0;
}

得到R1dIVHs2NzJjYzQ3NzhhMzhlODBjYjM2Mjk4NzM0MTEzM2VhMn0=

拿去base64解密:

Des = 'R1dIVHs2NzJjYzQ3NzhhMzhlODBjYjM2Mjk4NzM0MTEzM2VhMn0='
print(base64.b64decode(Des))

拿到NSSCTF{672cc4778a38e80cb362987341133ea2}

标签:26,加密,string,int,Des,flag,easyre,羊城,2020
From: https://www.cnblogs.com/TFOREVERY/p/17398874.html

相关文章

  • [省选联考 2020 A 卷] 组合数问题
    组合数问题首先明确下降幂即\[k^{\underlinem}=\sum_{i=k-m+1}^ki\]不难发现有\[\binom{n}{k}k^{\underlinem}=\binom{n-m}{k-m}n^{\underlinem}\]我们尝试把普通幂多项式转为下降幂多项式\[\sum_{i=0}^ma_ik^i=\sum_{i=0}^mb_ik^{\underlinei}\]由第二类斯特林数的......
  • 【攻防世界逆向】《re1-100》《EasyRE》《parallel-comparator-200》《simple-check-1
    题目re-100解法exeinfo无壳64位放进ida64上面很多内容,比较冗长,下面这些判断比较吸睛。大概就是进行一些对比后最后和一个字符串进行比较。直接提交,失败的。那我看一下上面的这个函数做了什么。是将这个字符串打乱了,打乱了之后才是下面那个。所以我们将原字符串10位分一个......
  • 2020年年终总结
    目录序言疫情到来学习娱乐个人公众号创建个人博客正式上线关于理财健康问题常回家看看2021年flag序言转眼间,2020年就这么过去了。2020对于每个人来说应该都是不平凡的一年,毕竟这一年太特殊了,一场席卷全世界的疫情来了。回想这一年,疫情改变了我们工作方式、生活方式。也让我们......
  • 6部10层电梯程序,采用以太网通信。 2020年西门子智
    6部10层电梯程序,采用以太网通信。2020年西门子智能制造挑战赛,6部10层电梯程序,包含各个功能模块。采用博途软件V14sp1编程,采用以太网通信,控制器选用PLCS7-1200。主要涉及逻辑控制、梯形图语言、置位复位。ID:4419662840760979......
  • 2020-05-19:催收核心业务是什么?
    如果不着急用钱,贷款最好别碰。当你没欠款的时候,诱导你欠款。当你欠款还不上的时候,会经常被骚扰,叫你还上。给我的感觉就是叫良家妇女入风尘,叫风尘女子从良。短信催收:快到期的时候,短信提示。电话催收:已经过期了,第一次电话,看是不是搞忘了。第N次电话,看怎么诱导优先还款。注意:欠钱的......
  • 2020-11-09:谈谈布隆过滤器和布谷鸟过滤器的相同点和不同点?
    福哥答案2020-11-09:相同点:都是过滤器。不同点:算法:布隆过滤器多个hash函数。布谷鸟过滤器用布谷鸟哈希算法。能否删除:布隆过滤器无法删除元素。布谷鸟过滤器可以删除元素,有误删可能。空间是否2的指数:布隆过滤器不需要2的指数。布谷鸟过滤器必须是2的指数。空间利用率:相同误判下......
  • 2020-05-21:es底层读写原理?倒排索引原理?
    es不熟悉,答案仅供参考:es写数据过程1、客户端选择一个node发送请求过去,这个node就是coordinatingnode(协调节点)2、coordinatingnode对document进行路由,将请求转发给对应的node(有primaryshard)3、实际的node上的primaryshard处理请求,然后将数据同步到replicanode。4、coord......
  • 2020-07-30-python-multithreading&multiprocessing
    注:参考Python多线程多进程那些事儿看这篇就够了~~进程、线程进程和线程简单举例:对于操作系统来说,一个任务就是一个进程(Process),比如打开一个浏览器就是启动一个浏览器进程。有些进程还不止同时干一件事,比如Word,它可以同时进行打字、拼写检查、打印等事情。在一个进程内部,要......
  • Codeforces [Hello 2020] 1284F New Year and Social Network(图论匹配推理+lct)
    https://codeforces.com/contest/1284/problem/F题目大意:有两个大小为n的树T1和T2.T2中的每条边(u,v)可以匹配T1中u到v路径上的所有边。求最大匹配,并给出方案。\(1<=n<=250000\)题解:首先你需要观察样例大胆猜想一定有完美匹配。考虑T1中的一个叶子x和它的父亲y。显然的是,从T2中随......
  • 【GDOI2020模拟02.05】生成树 (矩阵树扩展)
    Description:给定一张N个点,M条边的无向图,边有红、绿、蓝三种颜色,分别用1,2,3表示。求这张图有多少生成树,满足绿色边数量不超过x,蓝色边数量不超过y,答案对10^9+7取模。n<=40题解:考虑正常的用矩阵树求生成树个数的方法。基尔霍夫矩阵里的每个位置只是一个数,事实上可以把它扩......