OllyDbg 使用笔记 (七)
OllyDbg 使用笔记 (七)
參考
书:《加密与解密》
视频:小甲鱼 解密系列 视频
演示样例程序下载:http://pan.baidu.com/s/1gvwlS
暴力破解
观察这个程序。能够从程序标题的<unregistered 个跟 About 中的 <Unregistered Version>入手
用OD打开程序。右键-->查找-->全部參考文本字串
图片1
在打开的界面中。将滚动栏移到追上面(由于是从光标处開始搜索的),右键查找文本,先搜索<unregistered
图片2
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmlsbHZzbWU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
双击找到的文本到代码处。
005CC81B . E8 9C5FEDFF call 004A27BC
005CC820 . A1 8CEB6000 mov eax, dword ptr [60EB8C]
005CC825 . 8038 00 cmp byte ptr [eax], 0
005CC828 . 0F85 07010000 jnz 005CC935
005CC82E . A1 DCF16000 mov eax, dword ptr [60F1DC]
005CC833 . 8038 00 cmp byte ptr [eax], 0
005CC836 . 0F85 F9000000 jnz 005CC935
005CC83C . 68 70CB5C00 push 005CCB70 ; ASCII "PC Surgeon <unregistered - "
005CC841 . D905 3CCA5C00 fld dword ptr [5CCA3C]
005CC847 . A1 8CEC6000 mov eax, dword ptr [60EC8C]
005CC84C . DC20 fsub qword ptr [eax]
005CC84E . 83C4 F4 add esp, -0C
005CC851 . DB3C24 fstp tbyte ptr [esp]
005CC854 . 9B wait
细致查看。前面的跳转,能够发现 jnz 005CC935 非常关键。在前面一个jnz 005CC935处下断点,又一次执行程序,发现第这两个jnz 005CC935 未跳转。
把第一个cmp byte ptr [eax], 0 改成 cmp byte ptr [eax], 1 使跳转实现。
依照相同的方法,搜索<Unregistered Version>,跟改跳转实现。就可以破解程序。
其它方法
再来看看这段代码:
005CC811 . E8 12B9E6FF call <jmp.&shell32.ShellExecuteA> ; \ShellExecuteA
005CC816 > B8 58CB5C00 mov eax, 005CCB58 ; ASCII "Show: splash"
005CC81B . E8 9C5FEDFF call 004A27BC
005CC820 . A1 8CEB6000 mov eax, dword ptr [60EB8C]
005CC825 . 8038 00 cmp byte ptr [eax], 0
005CC828 . 0F85 07010000 jnz 005CC935
005CC82E . A1 DCF16000 mov eax, dword ptr [60F1DC]
005CC833 8038 00 cmp byte ptr [eax], 0
005CC836 0F85 F9000000 jnz 005CC935
005CC83C . 68 70CB5C00 push 005CCB70 ; ASCII "PC Surgeon <unregistered - "
005CC841 . D905 3CCA5C00 fld dword ptr [5CCA3C]
005CC847 . A1 8CEC6000 mov eax, dword ptr [60EC8C]
005CC84C . DC20 fsub qword ptr [eax]
005CC84E . 83C4 F4 add esp, -0C
005CC851 . DB3C24 fstp tbyte ptr [esp]
005CC854 . 9B wait
这里有两个jnz 005CC935 。推断分别推断[[60EB8C]] 跟 [[60F1DC]] 是否为0。 从 fld dword ptr [5CCA3C] 能够发现[5CCA3C]中是15.0 即试用天数。
细致分析能够发现第一个jnz为推断是否正常,第二个为推断是否超过15天使用期。
所以[[60EB8C]]的值很关键。
要找出改[[60EB8C]]的值的地方。
选中mov eax, dword ptr [60EB8C] , 右键-->查找參考-->地址常量。就可以列出全部使用了这个地址的命令的位置。
图片3
在此窗体右键-->在每一个命令上设置断点。又一次执行程序。
图片4
按F9,来到此处:
005C2BF6 . 8B15 8CEB6000 mov edx, dword ptr [60EB8C] ; pcsurgeo.00610C4A
005C2BFC . 8802 mov byte ptr [edx], al
005C2BFE . A1 8CEB6000 mov eax, dword ptr [60EB8C]
005C2C03 . 8038 00 cmp byte ptr [eax], 0
005C2C06 . 75 0D jnz short 005C2C15
005C2C08 . E8 6307EEFF call 004A3370
005C2C0D . A1 8CEC6000 mov eax, dword ptr [60EC8C]
005C2C12 . DD18 fstp qword ptr [eax]
005C2C14 . 9B wait
看到 mov byte ptr [edx], al 正是给[[60EB8C]] 赋值的地方,把它改成 mov byte ptr [edx], 1。就可以破解。
(在保存过程中会出现 重定位提示窗体,由于mov byte ptr [edx], al改成mov byte ptr [edx], 1后代码变多了。要重定位才可能正常执行。这里能够先不用管它。)
OllyDbg 使用笔记 (七)的更多相关文章
- 《MFC游戏开发》笔记七 游戏特效的实现(一):背景滚动
本系列文章由七十一雾央编写,转载请注明出处. http://blog.csdn.net/u011371356/article/details/9344721 作者:七十一雾央 新浪微博:http:// ...
- (转)Qt Model/View 学习笔记 (七)——Delegate类
Qt Model/View 学习笔记 (七) Delegate 类 概念 与MVC模式不同,model/view结构没有用于与用户交互的完全独立的组件.一般来讲, view负责把数据展示 给用户,也 ...
- OllyDbg 使用笔记 (二)
OllyDbg 使用笔记 (二) 參考 书:<加密与解密> 视频:小甲鱼 解密系列 视频 TraceMe.exe下载地址:http://pan.baidu.com/s/1c0s2twO T ...
- Learning ROS for Robotics Programming Second Edition学习笔记(七) indigo PCL xtion pro live
中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS forRobotics Pro ...
- Elasticsearch笔记七之setting,mapping,分片查询方式
Elasticsearch笔记七之setting,mapping,分片查询方式 setting 通过setting可以更改es配置可以用来修改副本数和分片数. 1:查看,通过curl或浏览器可以看到副 ...
- Typescript 学习笔记七:泛型
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- python3.4学习笔记(七) 学习网站博客推荐
python3.4学习笔记(七) 学习网站博客推荐 深入 Python 3http://sebug.net/paper/books/dive-into-python3/<深入 Python 3& ...
- Go语言学习笔记七: 函数
Go语言学习笔记七: 函数 Go语言有函数还有方法,神奇不.这有点像python了. 函数定义 func function_name( [parameter list] ) [return_types ...
- OllyDbg 使用笔记 (十二)
OllyDbg 使用笔记 (十二) 參考 书:<加密与解密> 视频:小甲鱼 解密系列 视频 演示样例程序下载地址:http://pan.baidu.com/s/1eQiV6aI 安装好程序 ...
随机推荐
- $P2299 Mzc和体委的争夺战$
\(problem\) #ifdef Dubug #endif #include <bits/stdc++.h> using namespace std; typedef long lon ...
- PHP电影小爬虫(2)
学习了别人的爬虫后自己改的一个,算是又回顾了一下php的使用 我们来利用simple_html_dom的采集数据实例,这是一个PHP的库,上手很容易.simple_html_dom 可以很好的帮助我们 ...
- MyBatis ((一对多和多对一配置)实现持久化操作 之二)
注: 此文中的实体类还是沿用上一章的Emp和Dept两个类 还是老样子,不细说 直接上代码 01.在emp.xml中 配置和Dept的多对一的相关信息 <?xml version=" ...
- Android 从服务器获取时间戳转换为年月日
用JAVA相关类转换.代码如下: Calendar calendar = Calendar.getInstance(); calendar.setTimeInMillis(NumberUtils.ge ...
- JS高级——面向对象方式解决歌曲管理问题
需要注意的问题: 1.其他模块若是使用构造函数MP3创建对象,唯一不同的就是他们传入的音乐库是不一样的,所以构造函数中存在一个songList属性,其他一样的就被添加到了构造函数的原型对象之中 2.原 ...
- (转)Hibernate关联映射——一对多(多对一)
http://blog.csdn.net/yerenyuan_pku/article/details/70152173 Hibernate关联映射——一对多(多对一) 我们以客户(Customer)与 ...
- iOS实现图形编程可以使用三种API(UIKIT、Core Graphics、OpenGL ES及GLKit)
这些api包含的绘制操作都在一个图形环境中进行绘制.一个图形环境包含绘制参数和所有的绘制需要的设备特定信息,包括屏幕图形环境.offscreen 位图环境和PDF图形环境,用来在屏幕表面.一个位图或一 ...
- CDR X8图框精确剪裁在哪?
对于CorelDRAW,刚从低版本升级为高版本的同学可能一下子理不清方向,因为在CorelDRAW X8中有很多功能命令做了整改和位置的变化.很多用户反映,CDR中的图框精确剪裁不见了,然而并不是该命 ...
- Web前端性能优化——提高页面加载速度
前言: 在同样的网络环境下,两个同样能满足你的需求的网站,一个“Duang”的一下就加载出来了,一个纠结了半天才出来,你会选择哪个?研究表明:用户最满意的打开网页时间是2-5秒,如果等待超过10秒, ...
- CentOS下修改root用户名
修改root登录用户名减少Linux云主机“被暴力破解”警告,登录云主机的时候就先显示登录失败多少次.其是公网有人在扫用弱密码破解登录. 所谓暴力破解,就是用“用户名“+”密码”穷举的方式进行远程登录 ...