吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 7873|回复: 26
收起左侧

[CTF] 一道linux ctf入门题逆向。

  [复制链接]
whyida 发表于 2017-11-9 11:14
本帖最后由 whyIDA 于 2017-12-1 11:45 编辑

下载地址:
https://www.52pojie.cn/forum.php ... &page=3#pid17643200
先用ida分析,main 函数入口。
[C] 纯文本查看 复制代码
int __cdecl main(int argc, const char **argv, const char **envp)
{
  int result; // eax
  __int64 v4; // [rsp+0h] [rbp-20h]
  __int64 v5; // [rsp+8h] [rbp-18h]
  __int16 v6; // [rsp+10h] [rbp-10h]
  int v7; // [rsp+14h] [rbp-Ch]
  int v8; // [rsp+18h] [rbp-8h]
  int i; // [rsp+1Ch] [rbp-4h]

  puts("welcome");
  v4 = 0x6D64616E696D6461LL;
  v5 = 0x3332313332316E69LL;
  v6 = 51;
  v8 = 0;
  for ( i = 0; i <= 16; ++i )
  {
    v7 = rand() % 255;
    if ( (unsigned int)check(v7, *((char *)&v4 + i), i) )
      ++v8;
  }
  if ( v8 == 17 )
    result = puts("good job,now you know what is flag!");
  else
    result = puts("wrong\ntry again!!!");
  return result;
}


check 函数
[C] 纯文本查看 复制代码
signed __int64 __fastcall check(unsigned int a1, unsigned int a2, int a3)
{
  int v4; // [rsp+10h] [rbp-50h]
  int v5; // [rsp+14h] [rbp-4Ch]
  int v6; // [rsp+18h] [rbp-48h]
  int v7; // [rsp+1Ch] [rbp-44h]
  int v8; // [rsp+20h] [rbp-40h]
  int v9; // [rsp+24h] [rbp-3Ch]
  int v10; // [rsp+28h] [rbp-38h]
  int v11; // [rsp+2Ch] [rbp-34h]
  int v12; // [rsp+30h] [rbp-30h]
  int v13; // [rsp+34h] [rbp-2Ch]
  int v14; // [rsp+38h] [rbp-28h]
  int v15; // [rsp+3Ch] [rbp-24h]
  int v16; // [rsp+40h] [rbp-20h]
  int v17; // [rsp+44h] [rbp-1Ch]
  int v18; // [rsp+48h] [rbp-18h]
  int v19; // [rsp+4Ch] [rbp-14h]
  int v20; // [rsp+50h] [rbp-10h]

  v4 = 7;
  v5 = 8;
  v6 = 12;
  v7 = 14;
  v8 = 21;
  v9 = 13;
  v10 = 13;
  v11 = 3;
  v12 = 28;
  v13 = 22;
  v14 = 110;
  v15 = 93;
  v16 = 64;
  v17 = 110;
  v18 = 93;
  v19 = 88;
  v20 = 78;
  if ( (a2 ^ a1) != *(&v4 + a3) )
    return 0LL;
  printf("%d,%d,%d\n", a1, a2, (unsigned int)*(&v4 + a3));
  putchar(a2 ^ a1);
  return 1LL;
}

关键代码
[C] 纯文本查看 复制代码
if ( (a2 ^ a1) != *(&v4 + a3) )

只要算出随机数就可得到flag
也就是a1=*(&v4 + a3) ^a2
[Python] 纯文本查看 复制代码
tmp=[7,8,12,14,21,13,13,3,28,22,110,93,64,110,93,88,78]
tmp2=[0x61, 0x64, 0x6d, 0x69, 0x6e, 0x61, 0x64, 0x6d,0x69,0x6E,0x31,0x32,0x33,0x31,0x32,0x33]
t=[]

for i in range(16):
        
    t= ((tmp[i])^(tmp2[i]))
        
    print(chr(t),end='')
    

捕获.JPG


捕获1.JPG

感谢 Dispa1r 的提醒,修改一处错误。

免费评分

参与人数 12威望 +1 吾爱币 +21 热心值 +11 收起 理由
Dispa1r + 1 + 1 用心讨论,共获提升!
只手过河 + 1 + 1 用心讨论,共获提升!
SomnusXZY + 1 + 1 热心回复!
Bad丶Boy + 1 + 1 大神。。。。
jaffa + 1 谢谢@Thanks!
Hmily + 1 + 10 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
bouc + 1 + 1 我很赞同!
hlink1021 + 1 + 1 热心回复!
silenceli + 1 + 1 热心回复!
DevinCc + 1 + 1 热心回复!
极地冷战 + 1 + 1 我很赞同!
lertty + 1 + 1 热心回复!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| whyida 发表于 2017-11-9 14:12
9152pojie 发表于 2017-11-9 13:34
怎么一下跑到python了,,,,

linux中许多地方需要用python。
Dispa1r 发表于 2017-12-1 08:41
zeromovie 发表于 2017-11-9 16:43
感谢楼主帮忙解题,问下tmp2是怎么得来的呢

tmp2楼主搞错了我感觉,【0x61, 0x64, 0x6d, 0x69, 0x6e, 0x61, 0x64, 0x6d,0x69,0x6E,0x31,0x32,0x33,0x31,0x32,0x33】,我感觉是这个,跑出来也没问题
李庆喜 发表于 2017-11-9 13:11
9152pojie 发表于 2017-11-9 13:34
怎么一下跑到python了,,,,
极地冷战 发表于 2017-11-9 14:34
支持新人
MAXtoDEATH 发表于 2017-11-9 14:36
楼上说支持新人的你看看lz比你高几权。。。
vv乐乐ai 发表于 2017-11-9 15:12
赞赞赞赞赞赞赞赞赞赞赞赞
zeromovie 发表于 2017-11-9 16:43
感谢楼主帮忙解题,问下tmp2是怎么得来的呢
 楼主| whyida 发表于 2017-11-9 17:36
zeromovie 发表于 2017-11-9 16:43
感谢楼主帮忙解题,问下tmp2是怎么得来的呢

主函数中:v4 = 0x6D64616E696D6461LL;在调试器中可以看到取字的完整过程。

亿联网络 发表于 2017-11-9 18:16
kali 就很6了,楼主渗透会不会,发点教程
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-8 21:33

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表