BUUCTF 刮开有奖1

首先下载文件打开

接下来按照惯例拖入exe

使用ida打开

按f5反编译

找到DialogFunc函数跟进

由strlen(String) == 8 得flag有八位,下面出现一个 sub_4010F0(v7, 0, 10);对v7进行处理,跟进看一下,

出现以下界面对v7进行处理,转换成语言看一下处理出来的v7是什么结果,

#include<stdio.h>
int sub_4010F0(int *a1, int a2, int a3);
int main()
{
    int v7[11]={90,74,83,69,67,97,78,72,51,110,103};
    sub_4010F0(v7 ,0 ,10);
    for(int i=0;i<11;i++){
        printf("%d ",v7[i]);
    }
    return 0;
    
 } 
int  sub_4010F0(int *a1, int a2, int a3)
{
  int result; // eax
  int i; // esi
  int v5; // ecx
  int v6; // edx

  result = a3;
  for ( i = a2; i <= a3; a2 = i )
  {
    v5 = i;
    v6 = a1[i];
    if ( a2 < result && i < result )
    {
      do
      {
        if ( v6 > a1[result] )
        {
          if ( i >= result )
            break;
          ++i;
          a1[v5] =a1[result];
          if ( i >= result )
            break;
          while ( a1[i] <= v6 )
          {
            if ( ++i >= result )
              goto LABEL_13;
          }
          if ( i >= result )
            break;
          v5 = i;
          a1[result] = a1[i];
        }
        --result;
      }
      while ( i < result );
    }
LABEL_13:
    a1[result] = v6;
    sub_4010F0(a1, a2, i - 1);
    result = a3;
    ++i;
  }
  return result;
}

运行结果为

接着回到Dialogfunc函数分析,

String[0] == v7[0] + 34可以得出flag第一位,v7[0]为51+34,字符则为‘U’,

&& String[1] == v10可以得出flag第二位,v10为74,字符则为‘J’;

接下来发现有两个字符串"ak1w","V1Ax";

双击跟进看一下

发现BCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=,所以猜测

"ak1w","V1Ax"是由base64加密,接下来借助工具

接下来接着分析if语句,

if ( String[0] == v7[0] + 34

&& String[1] == v10

&& 4 * String[2] - 141 == 3 * v8

&& String[3] / 4 == 2 * (v13 / 9)

&& !strcmp(v4, "ak1w")

&& !strcmp(v5, "V1Ax") )

由,

&& 4 * String[2] - 141 == 3 * v8,处理后的v8为69,得出flag第三位为87,字符为W

,&& String[3] / 4 == 2 * (v13 / 9),处理后v13为80,字符为P;

所以flag为flag{UJWP1jMp}.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值