码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [buuctf][WUSTCTF2020]level1


    [WUSTCTF2020]level1

    • 思路
    • 脚本

    思路

    先查壳,发现是无壳的64位的一个可执行文件。
    在这里插入图片描述
    放入ida中,发现有main函数,这道题看来是难度不大

    int __cdecl main(int argc, const char **argv, const char **envp)
    {
      FILE *stream; // ST08_8
      signed int i; // [rsp+4h] [rbp-2Ch]
      char ptr[24]; // [rsp+10h] [rbp-20h]
      unsigned __int64 v7; // [rsp+28h] [rbp-8h]
    
      v7 = __readfsqword(0x28u);
      stream = fopen("flag", "r");
      fread(ptr, 1uLL, 0x14uLL, stream);
      fclose(stream);
      for ( i = 1; i <= 19; ++i )
      {
        if ( i & 1 )
          printf("%ld\n", (unsigned int)(ptr[i] << i));
        else
          printf("%ld\n", (unsigned int)(i * ptr[i]));
      }
      return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    之后附件中还有一个txt文件,打开发现是一堆数字,之后利用这个逻辑进行运算即可,那么脚本就写出来。

    脚本

    #include<stdio.h>
    #include<string.h>
    #include<stdlib.h>
    #include<stdint.h>
    int main() {
    	int output[20] = {0,198,232,816,200,1536,300,6144,984,51200,570,92160,1200,565248,756,1474560,800,6291456,1782,65536000};
        for (int i = 1; i <= 19; ++i)
        {
            if (i & 1)
                printf("%c", (unsigned int)(output[i] >> i));
            else
                printf("%c", (unsigned int)( output[i]/i  ));
        }
    }
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    最后获得flag是ctf2020{d9-dE6-20c}
    之后用flag包裹flag{d9-dE6-20c}

  • 相关阅读:
    工程管理系统简介 工程管理系统源码 java工程管理系统 工程管理系统功能设计
    长难句分析
    Acrel-EIoT能源物联网云平台助力电力物联网数据服务-Susie 周
    GitHub常用命令
    半导体工厂将应用哪些制造创新技术?
    解读MySQL 8.0数据字典的初始化与启动
    python-pandas用法大全
    【Azure Developer】App Service + PubSub +JS 实现多人版黑客帝国文字流效果图
    Session详解(重点)
    [附源码]java毕业设计放肆游旅游网
  • 原文地址:https://blog.csdn.net/m0_71081503/article/details/125500109
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号