首页 > 其他分享 >DACTF 2023 七月赛 websever

DACTF 2023 七月赛 websever

时间:2023-08-15 20:46:18浏览次数:48  
标签:10 enc 0x00000010 0x00000063 DACTF range 0x00000001 2023 websever

解题过程

IDA打开,函数很多,而且全是sub_ 没有符号,查看下字符串,看到了/flag /check,还有很多oatpp3的字符串,查了下,这是个C++的web库和名字很符合,先编译一份,参考

[]  https://blog.csdn.net/qq_44519484/article/details/123250415 

image-20230815200620596

编译完使用IDA打开,然后bindiff导入,全选导入符号,有的可能不准,能好看点就行,先打开我们自己编译的hello,world 我们的程序访问hello是有回显的,交叉引用找过去,这个函数看名字就挺像响应的

image-20230815201641372

然后去题目里面找函数,虽然恢复了符号,但是函数的名称怪怪的,不是这种otapp::的格式,中间没有分割。搜索createResponse,找到两个,点进去,然后找交叉引用,看哪个比较像加密

image-20230815201952748

第三个sub_40617E,一个大数组,后面是计算,一看就很像加密

image-20230815202030596

image-20230815202527971

这里大概就是两个数组,类似矩阵乘法,然后最后再遍历一遍,有个IF判断是否是0,如果是0就跳到正确的分支,使用Z3可以直接求解出来,

z3的一些语法

#创建了一个Solver对象s,用于解决后续添加的约束
s=Solver()
#添加约束条件
s.add(enc[i]==0)
#sat表示“满足的”或“可解的”,意味着所有约束都可以同时满足,并存在一个解决方案。
s.check()==sat
#获取解决方案
m = s.model()


.as_long() 从Z3模型中提取出的整数值。

 

solever.py

from z3 import *
key=[0x00000017, 0x0000000D, 0x00000004, 0x00000030, 0x00000029, 0x00000029, 0x0000002A, 0x00000021, 0x0000001E, 0x00000003, 0x00000045, 0x00000001, 0x0000000D, 0x0000002D, 0x00000029, 0x00000040, 0x00000008, 0x00000050, 0x0000000F, 0x0000002A, 0x00000038, 0x00000013, 0x0000003E, 0x00000046, 0x00000017, 0x0000003F, 0x0000001E, 0x00000044, 0x00000011, 0x00000038, 0x0000005C, 0x0000000C, 0x00000010, 0x00000040, 0x0000001F, 0x00000003, 0x00000011, 0x00000047, 0x0000003A, 0x00000009, 0x00000040, 0x00000053, 0x00000047, 0x00000034, 0x00000063, 0x00000059, 0x0000004C, 0x00000044, 0x00000001, 0x00000063, 0x00000010, 0x00000010, 0x00000034, 0x0000002B, 0x00000000, 0x0000002C, 0x00000032, 0x00000020, 0x00000032, 0x0000001F, 0x00000014, 0x0000003F, 0x00000002, 0x00000063, 0x00000000, 0x00000039, 0x0000004F, 0x0000002B, 0x00000047, 0x00000013, 0x00000050, 0x0000005C, 0x0000005D, 0x0000003A, 0x00000054, 0x0000004A, 0x00000051, 0x0000002D, 0x00000037, 0x00000015, 0x00000001, 0x00000063, 0x0000001E, 0x0000001C, 0x00000038, 0x00000001, 0x0000000C, 0x0000004D, 0x0000005C, 0x00000004, 0x00000025, 0x00000043, 0x0000003C, 0x00000036, 0x00000033, 0x0000004F, 0x00000026, 0x00000057, 0x00000030, 0x00000010]
enc=[0]*40
enc[0] = 33211
enc[1] = 36113
enc[2] = 28786
enc[3] = 44634
enc[4] = 30174
enc[5] = 39163
enc[6] = 34923
enc[7] = 44333
enc[8] = 33574
enc[9] = 23555
enc[10] = 35015
enc[11] = 42724
enc[12] = 34160
enc[13] = 49166
enc[14] = 35770
enc[15] = 45984
enc[16] = 39754
enc[17] = 51672
enc[18] = 38323
enc[19] = 27511
enc[20] = 31334
enc[21] = 34214
enc[22] = 28014
enc[23] = 41090
enc[24] = 29258
enc[25] = 37905
enc[26] = 33777
enc[27] = 39812
enc[28] = 29442
enc[29] = 22225
enc[30] = 30853
enc[31] = 35330
enc[32] = 30393
enc[33] = 41247
enc[34] = 30439
enc[35] = 39434
enc[36] = 31587
enc[37] = 46815
enc[38] = 35205
enc[39] = 20689
inp = [Int('inp%d' % i) for i in range(len(enc))]
s=Solver()
flag=''
for k in range(4):
   for m in range(10):
       for n in range(10):
           enc[10 * k + m] -=inp[10 * k +  n] * key[10 * n + m]
for i in range(len(enc)):
   s.add(enc[i]==0)

if s.check()==sat:
   m=s.model()
   for i in range(40):
       flag+=chr(m[inp[i]].as_long())
   print(flag)
 

标签:10,enc,0x00000010,0x00000063,DACTF,range,0x00000001,2023,websever
From: https://www.cnblogs.com/immune53/p/17632380.html

相关文章

  • 一文预览 | 8 月 16 日 NVIDIA 在 WAVE SUMMIT深度学习开发者大会 2023精彩亮点抢先看
    由深度学习技术及应用国家工程研究中心主办,百度飞桨和文心大模型承办的WAVESUMMIT深度学习开发者大会2023,将于8月16日在北京与大家见面。NVIDIA作为技术合作伙伴,将携手百度飞桨参与这场技术盛会。在这次大会中,NVIDIA与飞桨共规划了四大活动亮点,包括NVIDIA人工智能工作坊—......
  • 2023.3.24杂谈【化学×情感】
    今天的化学课上,老师讲了这样一个方程式:\[3Cu+2HNO_3+3H_2SO_4\stackrel{}{=\!=\!=}3CuSO_4+2NO\uparrow+4H_2O\]当硝酸少量时,它只表现出了氧化性,而并未表现出酸性。这何尝不是一种\(NTR\),硝酸经过努力,终于将\(Cu\),这个冷漠的元素氧化,却让后来居上的硫酸占据,硝酸自......
  • [LitCTF 2023]1zjs
    [LitCTF2023]1zjs题目来源:nssctf题目类型:web涉及考点:信息搜集1.题目给了一个魔方游戏,检查源代码:在/dist/index.umd.js里发现线索:直接访问看看:经查询发现是JSFuck编码,特征为[]+!(),对其解码得到:将[]去掉即可得到flag:NSSCTF{11c9e8fe-03f7-4bc1-bfed-b8277cd55964}......
  • 2023RISC-V中国峰会,澎峰科技成果发布抢先看!
    2023RISC-V中国峰会(RISC-VSummitChina2023)将于8月23日至25日在北京香格里拉饭店举行。本届峰会将以“RISC-V生态共建”为主题,结合当下全球新形势,把握全球新时机,呈现RISC-V全球新观点、新趋势。本届峰会采用“主会议+技术研讨会+展览展示+同期活动”的方式,预计将举办超过2......
  • 阿里云容器服务 ACK 产品技术动态(202307)
    ......
  • 闲话 2023.8.15
    一些算式的证明。\[\begin{aligned}\sum_{1\lei<j\len}i+j&=\sum\limits_{i=1}^{n-1}\left(\sum\limits_{j=i+1}^{n}j+\sum\limits_{j=i+1}^{n}i\right)\\&=\sum\limits_{i=1}^{n-1}\left[\dfrac{\left(n+i+1......
  • 华为开发者大会2023:云空间筑牢鸿蒙生态“云基因”
    8月4日,华为开发者大会2023在东莞·松山湖举办,众多开发者及合作伙伴共赴盛会,见证鸿蒙生态的最新进展。在本届大会的HarmonyOS应用开发(端云能力)分论坛上,华为DriveKit生态架构技术总监官宣云空间服务升级,赋能开发者高效开发,为鸿蒙生态应用注入“云基因”。构建端云数据同步服务,为......
  • 2023杭电多校第九场
    目录比赛地址:传送门赛时过了4题,继续加油哈~......
  • 2023/08/15
    15个猴子围成一圈选大王,依次1-7循环报数,报到7的猴子被淘汰,直到最后一只猴子称为大王,问:哪只猴子会成为大王?package练习;publicclassMonkeyKing{publicstaticvoidmain(String[]args){boolean[]b=newboolean[15];for(inti=0;i<b.lengt......
  • 2023牛客暑期多校训练营7
    C.BeautifulSequence题意:有长为\(n\)的数组\(a\),通过操作\(a_i\oplusa_{i+1}\)得到\(b_i\),现在给出数组\(b\),求出字典序第\(k\)小的数组\(a\)Solution不难发现,如果确定了\(a_1\)的某一二进制位上的数,就可以确定整个数组\(a\)的这一位上的数,我们首先把所有的二进制位数都变......