第四十七题讲解攻防世界之easyCpp

easyCpp

这个刚开始看的话,确实有点看不下去!所以我直接动态调试,调试到最后看看能不能出flag!
第四十七题讲解攻防世界之easyCpp
所以我又开始了静态分析!
第四十七题讲解攻防世界之easyCpp
此时我们可以去fib函数里面看看!
第四十七题讲解攻防世界之easyCpp
这里是个递归!最后应该将数列储存在了LODWORD(v29)这里了!

C++的确实这里没有学过!

容器(Containers) 容器是用来管理某一类对象的集合。C++ 提供了各种不同类型的容器,比如 deque、list、vector、map 等。

算法(Algorithms) 算法作用于容器。它们提供了执行各种操作的方式,包括对容器内容执行初始化、排序、搜索和转换等操作。

迭代器(iterators) 迭代器用于遍历对象集合的元素。这些集合可能是容器,也可能是容器的子集。

STL的知识确实没有学习过,这里其实是凭借着经验主义来行事的!
第四十七题讲解攻防世界之easyCpp
然后我们进去看看!
第四十七题讲解攻防世界之easyCpp
此时我们就需要搞懂这两个函数到底时干什么的!
第四十七题讲解攻防世界之easyCpp
然后再经过循环看看结果,从而推导出这里的加密方式!
第四十七题讲解攻防世界之easyCpp
还有就是分析的时候要注意是地址还是地址里面的内容!
第四十七题讲解攻防世界之easyCpp
那个判断应该就是判断是否输入与斐波那契数列是否一致!
这样的话是可以找到我们要输入什么,知道了输入什么正确也就意味着flag找到了!
第四十七题讲解攻防世界之easyCpp
第四十七题讲解攻防世界之easyCpp
此时我们就可以开始写脚本了!

def fib(i):#模拟斐波那契数列
    if not i or i == 1:
        return 1
    j = fib(i - 1)
    return j + fib(i - 2)

data = [0] * 16
j = 15
for i in range(16):
    data[j] = fib(i)
    j -= 1
print(data)#模拟逆序
for i in range(1,len(data)):#模拟将其进行斐波那契规律
    print(data[i] - data[0])

然后输入这个数组就可以了!
第四十七题讲解攻防世界之easyCpp


上一篇:day04_04 斐波那契


下一篇:Go: 函数