news 2026/5/12 10:06:11

《静态分析:GUI程序的明码比较》

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《静态分析:GUI程序的明码比较》

首先在detect it easy中进行查壳

可以得到以下信息

  • 文件大小:81.50 KiB

  • 文件类型:PE32(32位Windows可执行文件)

  • 操作系统兼容性:Windows XP(但可能兼容更高版本)

  • 程序类型:GUI程序(非控制台程序)

  • 编译器:Microsoft Visual C/C++(版本 19.00.23026)

  • 链接器:Microsoft Linker(版本 14.00.23026)

  • 工具链:Microsoft Visual Studio 2015

  • 编译模式:LTCG(链接时代码优化)/ C++

  • 语言:C++

  • 包含PDB调试信息:是(有绝对路径PDB)

  • 调试数据位置

    • 偏移:0x00010044

    • 大小:0x65(101字节)

  • PDB版本:7.0

这是一个32位 GUI 程序(Windows XP 兼容),所以入口是WinMain(不是main)。

然后进入IDA中查看

WinMain直接调用了DialogBoxParamW,说明这是一个基于对话框的 GUI 程序。关键逻辑在DialogFunc这个对话框过程函数里。

在 IDA 的函数列表(Functions window)里找DialogFunc,或者按Ctrl + F搜索DialogFunc

如果没找到这个名字,可以:

  • 双击WinMain里的DialogFunc(IDA 会跳转过去)

  • 或者在汇编视图里看DialogBoxParamW的第四个参数(通常是 push 一个地址)

程序要求两个输入:

  1. String→ 从控件1001获取(应该是邮箱输入框)

  2. v11→ 从控件1002获取(应该是注册码/flag 输入框)

📧 邮箱验证条件:

if ( strstr(String, "@") && strstr(String, ".") && strstr(String, ".")[1] && strstr(String, "@")[1] != 46 )

要求:

  • 包含@

  • 包含.

  • .后面至少还有一个字符(防止以点结尾)

  • @后面的字符不能是.(防止@.出现)

只要邮箱格式大致正确即可,比如a@b.c就满足。

Flag的验证逻辑

if ( strlen(v11) == 16
&& v11[0] == 67 // 'C'
&& v11[15] == 88 // 'X'
&& v11[1] == 90 // 'Z'
&& v11[14] == 65 // 'A'
&& v11[2] == 57 // '9'
&& v11[13] == 98 // 'b'
&& v11[3] == 100 // 'd'
&& v11[12] == 55 // '7'
&& v11[4] == 109 // 'm'
&& v11[11] == 71 // 'G'
&& v11[5] == 113 // 'q'
&& v11[10] == 57 // '9'
&& v11[6] == 52 // '4'
&& v11[9] == 103 // 'g'
&& v11[7] == 99 // 'c'
&& v11[8] == 56 ) // '8'

当输入:

  • 邮箱:任意有效邮箱(如test@test.com

  • 注册码:CZ9dmq4c8g9G7bAX

然后就可以确定flag

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/12 10:06:10

Linux用户与组管理:系统安全的基石

为什么用户与组如此重要?想象一下一个没有门禁和权限管理的大厦——任何人都可以进入任何房间,查看任何文件。Linux的用户与组系统就是这个数字大厦的安全门禁系统,它决定了“谁可以做什么”。核心概念:UID、GID与权限模型用户标识…

作者头像 李华
网站建设 2026/5/12 10:06:00

kanass全面介绍(17) - 如何进行工时管理,有效度量项目资源

kanass是一款开源免费的项目管理工具,工具轻量、简洁易用,本篇文章将通过如何添加工时、修改工时、查看和统计工时等方面来介绍工时管理。1、添加工时工时的作用:用来记录事项所花费的时间,并通过预估和剩余时间,来自动…

作者头像 李华
网站建设 2026/5/8 21:59:22

2025年商业生态系统中的战略协同与价值创造

在2025年的商业生态系统中,战略协同与价值创造成为企业成功的关键要素。随着市场环境的变化和技术的进步,企业意识到单打独斗已无法满足日益复杂的需求。因此,跨界合作和资源共享逐渐成为主流趋势。通过建立多方协作网络,不同企业…

作者头像 李华
网站建设 2026/5/8 21:58:11

【建议收藏】GCC 编译器常用选项速查表(附助记词)

作者:嵌入式兔哥 简介:在嵌入式开发中,GCC 是我们最忠实的伙伴。很多兄弟可能只习惯用 IDE 的一键编译,但一旦转战 Linux 环境或编写 Makefile,理解 GCC 的这些参数就成了基本功。今天兔哥帮大家整理了一份“不求人”的…

作者头像 李华