破解 RCA_CRACKME(解除隐藏按钮)
系统 : Windows xp
程序 : RCA_CRACKME
程序下载地址 :http://pan.baidu.com/s/1bnoOQ6
要求 : 注册机编写
使用工具 : IDA Pro & OD
可在“PEDIY CrackMe 2007”中查找关于此程序的讨论,标题为“RCA Crackme 简单分析”。
运行程序输入测试用户名密码,准备进行测试。发现check it!!!按钮被隐藏了,无法单击。怀疑这里用了隐藏按钮窗口的API函数,这里我们使用IDA载入程序,发现左侧函数名称中的确有“EnableWindow”函数。双击定位,双击交叉参考进入程序调用它的位置:
.text: push 3EEh ; nIDDlgItem
.text: push [ebp+hDlg] ; hDlg
.text:0040106C call GetDlgItem
.text: mov [ebp+hWnd], eax
.text: or eax, eax
.text: jnz short loc_401087
.text: push ; bEnable
.text:0040107A push [ebp+hWnd] ; hWnd
.text:0040107D call EnableWindow
.text: jmp loc_40112A
.text: ; ---------------------------------------------------------------------------
.text:
.text: loc_401087: ; CODE XREF: DialogFunc+36j
.text: push ; bEnable
.text: push [ebp+hWnd] ; hWnd
.text:0040108C call EnableWindow
.text: jmp loc_40112A
可以看到,程序调用GetDlgItem的返回值做判断,根据参数不难发现,这里的GetDlgItem是WinAPI函数。打开OD,将401076处的代码改成“jz short 00401087”即可解除隐藏按钮。
接着一开始,我们输入测试用户名密码,并根据提供的错误字串找到关键算法:
0040115E |. push edi ; /String => ""
0040115F |. E8 call <jmp.&kernel32.lstrlenA> ; \lstrlenA
|. 8BD8 mov ebx, eax ; 用户名长度保存在ebx中
|. 33C0 xor eax, eax
|> /push eax
|. |push ebx ; 长度入栈
0040116A |. |push edi ; 字串地址入栈
0040116B |. 0FBE0C38 |movsx ecx, byte ptr [eax+edi] ; 逐个取字符
0040116F |. |push ecx ; /<%x>
|. |push ; |Format = "%x"
|. |push ; |s = CrackMe.00403168
0040117A |. E8 D3000000 |call <jmp.&user32.wsprintfA> ; \wsprintfA
0040117F |. 83C4 0C |add esp, 0C ; 平衡堆栈
|. |push ; /StringToAdd = ""
|. |push ; |ConcatString = ""
0040118C |. E8 0F010000 |call <jmp.&kernel32.lstrcatA> ; \lstrcatA
|. 5F |pop edi
|. 5B |pop ebx
|. |pop eax
|. |inc eax ; 循环变量自增
|. 3BC3 |cmp eax, ebx
|.^ 7C CF \jl short
|. push ; /String2 = ""
0040119E |. push ; |String1 = ""
004011A3 |. E8 FE000000 call <jmp.&kernel32.lstrcmpA> ; \lstrcmpA
004011A8 |. 0BC0 or eax, eax
004011AA |. 4A jnz short 004011F6
004011AC |. 6A push ; /Style = MB_OK|MB_APPLMODAL
004011AE |. push ; |Title = "Reverse Engineering Association"
004011B3 |. push ; |Text = "Congratulation! You've done with it"
004011B8 |. FF75 push dword ptr [ebp+] ; |hOwner
004011BB |. E8 C2000000 call <jmp.&user32.MessageBoxA> ; \MessageBoxA
004011C0 |. EC030000 push 3EC ; /ControlID = 3EC (1004.)
004011C5 |. FF75 push dword ptr [ebp+] ; |hWnd
004011C8 |. E8 A3000000 call <jmp.&user32.GetDlgItem> ; \GetDlgItem
004011CD |. FC mov dword ptr [ebp-], eax
004011D0 |. 6A push ; /Enable = FALSE
004011D2 |. FF75 FC push dword ptr [ebp-] ; |hWnd
004011D5 |. E8 8A000000 call <jmp.&user32.EnableWindow> ; \EnableWindow
004011DA |. ED030000 push 3ED ; /ControlID = 3ED (1005.)
004011DF |. FF75 push dword ptr [ebp+] ; |hWnd
004011E2 |. E8 call <jmp.&user32.GetDlgItem> ; \GetDlgItem
004011E7 |. F8 mov dword ptr [ebp-], eax
004011EA |. 6A push ; /Enable = FALSE
004011EC |. FF75 F8 push dword ptr [ebp-] ; |hWnd
004011EF |. E8 call <jmp.&user32.EnableWindow> ; \EnableWindow
004011F4 |. EB jmp short 0040120A
004011F6 |> 6A push ; /Style = MB_OK|MB_APPLMODAL
004011F8 |. push ; |Title = "Reverse Engineering Association"
004011FD |. push ; |Text = "No,no! Try it again!"
|. FF75 push dword ptr [ebp+] ; |hOwner
|. E8 call <jmp.&user32.MessageBoxA> ; \MessageBoxA
以上就是关键处算法,用户名字串的十六进制码既是密钥。
打开http://www.cnblogs.com/ZRBYYXDM/p/5002789.html中搭建的MFC窗口程序,修改OnOk函数如下:
void CSerialNumber_KeygenDlg::OnOK()
{
// TODO: Add extra validation here
CString str;
GetDlgItem( IDC_EDIT_NAME )->GetWindowText( str ); //获取用户名 int len = str.GetLength(); //获取长度
CString SerialNumber,Temp; for ( int i = ; i != len ; i++ ){
Temp.Format( "%x",str[i] );
SerialNumber += Temp;
} GetDlgItem( IDC_EDIT_Number )->SetWindowText( SerialNumber ); //CDialog::OnOK(); //屏蔽基类OnOk函数
}
再在OnInitDialog中添加此代码修改标题:SetWindowText(_T("RCA_CRACKME_Keygen"));
运行效果:

破解 RCA_CRACKME(解除隐藏按钮)的更多相关文章
- iOS 为键盘添加隐藏按钮
// 为键盘添加隐藏按钮 UIToolbar * backView = [[UIToolbar alloc]initWithFrame:CGRectMake(, , , )]; [backView s ...
- JS如何调用隐藏按钮的click事件
js如何调用隐藏按钮的click事件:1.设定隐藏不要使用Visiable属性,使用style.display=none:2.触发JS事件可以使用fireEvent方法,如:document.getE ...
- openerp学习笔记 视图(tree\form)中隐藏按钮( 创建、编辑、删除 ),tree视图中启用编辑
视图(tree\form)中隐藏按钮( 创建.编辑.删除 )create="false" edit="false" delete="false&quo ...
- layerui如何隐藏按钮?
https://www.layui.com/doc/modules/layer.html#btn 建议把 btn: ['取消'],btnAlign: 'c',yes: function (index) ...
- WIN7 X64 下 VS2008升级补丁 (显示隐藏按钮)
原文地址:http://blog.sina.com.cn/s/blog_57b5da120100gk7l.html 更新列表: 2010年3月26日:增加对日文版的支持. 2010年3月3日:更新代码 ...
- Android 浮动按钮+上滑隐藏按钮+下滑显示按钮
1.效果演示 1.1.关注这个红色的浮动按钮 . 可以看到,上滑的时候浮动按钮消失,因为用户迫切想知道下面的东西,而不是回到顶部. 当下滑的时候,用户想回到原来的位置,就可以点击浮动按钮,快速回到顶部 ...
- 隐藏按钮button
<td> <input id="del" type="button" value="删除" onclick="u ...
- jquery隐藏按钮
$(function () { jhbs = getQueryStringByName('jhbs'); shhbs = getQueryStringByName('shhbs'); if (shhb ...
- openerp编辑与非编辑下隐藏按钮的方法
在form表单中,有些控件希望在编辑的时候显示,非编辑时不显示,如hr模块的员工表单,在非编辑模式中,姓名的title不显示,而在编辑模式中显示出来.我们可以在xml文件中给控件赋属性值,class= ...
随机推荐
- 大作业关于(“有爱”youi)的简介
我们团队一共四个人,我们足够了解对方的优缺点,能够很好的进行交流沟通.对于一些问题也能有好的方法去解决,我做事情比较讲究高效和尽可能的完美,或者说要做到我自己觉得完美,才会停下来.对于一件事情,我有自 ...
- JFrame背景
1.引言 在了解了JFrame面板的相关知识后,我们可以选择在RootPane根面板或LayeredPane面板中设置背景图案. 2.方法 对于大小固定的窗口背景设置如下: //导入图案 ImageI ...
- shell脚本流程搭建
程序中删除文件夹即用rm -rf ${Dir} rm -f ${Dir}/* rm -f ${Dir}* 的时候要注意先检查路径变量是否有定义不为空. if [ ! -z ${LogDir} ]; t ...
- Excel中连接函数CONCATENATE()
直接API: CONCATENATE 函数语法具有下列参数 (参数:为操作.事件.方法.属性.函数或过程提供信息的值.): Text1 必需. 要连接的第一个文本项. Text2, ... 可选. 其 ...
- urlrewrite伪静态 及多参数传递-附正则表达式语法 [轉]
首先 加载 urlrewrite包 配置web.xml [list] [*] <error-page> [*] <error-code>404</ ...
- 使用Matrix控制图像或组件变换的步骤
1.获取Matrix对象,该Matrix对象既可新创建,也可直接获取其他对象内封装的Matrix(例如Transformation对象内部) 2.调用Matrix的方法进行平移.旋转.缩放.倾斜等. ...
- 对于服务器的识别的条件,header之类的使用
根据上一节的内容的衔接 一:urllib.request的使用 headers的一些属性 User-Agent : 有些服务器或 Proxy 会通过该值来判断是否是浏览器发出的请求Content-Ty ...
- eclipse debug时老提示edit source lookup path解决方案
用myeclipse debug web应用的时候,总提示edit source lookup path,每次都得手动选择项目,费时费力.在网上终于找到了方法. 搬运:http://www.educi ...
- C++定义构造函数必须使用初始化列表的场合
明其理,而知其然也. 先给理论.1. 初始化 != 赋值. a.初始化代表为变量分配内存. 变量在其定义处被编译器初始化(编译时). 在函数中, 函数参数初始化发生在函数调用时(运行时). b.赋值代 ...
- 安装svnx2出现 Make sure an svn tool (≥ v1.6) is present in the folder: “/usr/bin”
安装svnx2出现 Make sure an svn tool (≥ v1.6) is present in the folder: “/usr/bin” 是因为svnx2需要用到svn的地址,修改为 ...