关于SkinMagic的破解

SkinMagic是一个换肤控件库,但是在我们使用的过程中会有一些问题出现,比如将它加在我们的应用程序上时,每次打开程序都会出现一个未注册的对话框。为了使得这个对话框不出现,则需要进行破解工作。现在网上关于SkinMagic的破解主要还是以 掌门狗 的方法为主,他破解了包括SkinMagic2.2版的各种动态库,而且方法比较简单,也给出了说明。这里我用了一种比较简陋的方法破解SkinMagic2.2版的SkinMagicTrial.dll文件,解决之前说的那个弹出未注册对话框的问题。对于最新的SkinMagic2.4,虽然也可用类似的方法做,但是应用在程序中时会出现断言异常(似乎未破解也是这样……)。

下面我说说具体的过程:

首先需要准备反汇编工具W32dsm8.93,这个很著名的,可以在看雪学院的网站上下到(那里还有好多类似的工具!),然后需要准备一个能够写十六进制的软件,比如UltraEdit或者WinHex。

工具准备好了以后,就可以开始干活了。首先将应用程序加载SkinMagic动态库并编译运行(这里以VC6.0为例,编译版本选择Debug,但破解后对Release仍旧适用),这时可以看到弹出一个未注册对话框。关闭程序,打开W32dsm8.93,选择反汇编->打开文件,然后选择刚才加载的那个SkinMagicTrial.dll文件(由于SkinMagic2.2版的这个动态库没有加壳,所以可以直接打开做静态分析,如果打开发现有问题可以通过peid这个工具检查动态库是否加壳,然后再选择相应的脱壳软件脱掉壳既可,这里我们不讨论关于脱壳的技术)。

待分析完成后,选择参考->串式参考,然后在弹出的对话框中找到"This application uses trial version "这个字符串,然后双击它到达引用它的地方,如下图所示。

亮蓝色的部分式引用这个字符串的位置,观察它的上下文,可以发现这块代码由四个连着的push组成,而后call了一个子程序,看引用说明是call USER32.MessageBoxA,这就再清楚不过了:这部分首先压了四个参数入栈,而后将它们用于MessageBoxA这个api函数用于显示对话框,而显示的内容又是This application uses trial version这个字符串,显然这里就是弹出的那个未注册对话框。

由以上分析可以看出,动态库从1000617A这个地方开始送参数入栈,到10006192开始调用显示对话框。这样后面的工作就轻松多了,打开UltraEdit,然后打开SkinMagicTrial.dll(之前记得吧WDasm关了),用Ctrl+G找到000617A这个地方,然后从这里到0006192为止,统统使用十六进制数90替换就可以了(90在汇编中是nop指令,代表空操作,即什么也不做),最后保存退出。

破解完成了,看看效果吧,回到VC6,运行应用程序,发现那个未注册对话框不见了,至此破解成功。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自己下载正式版2.3,二进制下自己破解。参考偷梁换柱破解SkinMagic_百度文库中的文档,思想是PostMessageA替换MessageBoxA。下面是帖子的具体内容 不知道有多少像本人一样一直热爱着vc的人存在,应该很多吧.虽然CB也用的是c++的语法,但是由于是个人偏激吧,不太喜欢,所以就一直忍受着做界面的痛苦.用Vc写程序的都知道,MFC做界面是多么痛苦的事情,动不动就要继承,封装....十分的郁闷。以后前段时间让我遇到了SkinMagicToolkit,才知道,世界上既然还有那么可爱的软件存在(帮作者做一下广告先),简单的调用几句代码,就可以改变界面皮肤~换皮肤也很简单。真是个好东西~.好了,不说多废话了,开始。 我下载的是SkinMagicToolkit2.21.下载回来以后,发现按照例子调用以后,可以是可以改变皮肤,但是都会在程序界面显示前跳出一个对话框,显示内容是:ThisapplicationusestrialversionofSkinMagicToolkit.Youcanregisterathttp://www.appspeed.com 真难看,破解!把这个难看的对话框去掉。先检查壳。结果是没有~好~用W32dsm8.93中文版.先进行静态分析.SkinMagic里所有的函数其实就是在SkinMagicTrial.dll这里面了.用W32dsm8.93打开SkinMagicTrial.dll。然后"参考"->"串式参考".找到对话框信息.一直往下翻.看见这个信息"Thisapplicationusestrialversion",双击。这个时候,程序代码来到了:100061816878BC0510push1005BC78.字符信息就是在这里入栈的.往下看几行,把MessageBoxA的4个参数都入栈了以后,再下两行就是MessageBoxA函数的调用处了,在:10006192FF150c040510,这里就是调用MessageBoxA的地方.好的,马上用最简单的办法,把这里的入栈的4个参数都用nop给替换掉.我用的是Hiewv6.81。不一会,就把这4个push*****替换成了nop。马上运行已经写好的程序,因为程序是调用SkinMagicTrial.dll的,所以不用改任何程序的代码,就可以运行了。结果发现,跳出错误对话筐,说程序初始化错误,就退出了程序.....真郁闷....难道程序在其他的地方检查了Eax寄存器?Eax寄存器是用来保存每个函数调用完以后的返回值的.算了,我也懒得麻烦去做其他的事情了,要的就是爆破.仔细想一下,有什么函数也是调用4个参数的,而且要SkinMagicTrial.dll已经倒入的。有了! PostMessageA,马上看一下PostMessageA在SkinMagicTrial.dll中的地址."菜单"->"函数"->"输入",然后找到PostMessageA.双击,看见了PostMessageA的调用地址: 10023FF1FF15C4030510.好的,等一下就可以在:10006192FF150C040510,把FF150C040510替换成为FF15C4030510就可以了.因为PostMessageA也有返回值.呵呵。破解成功。这样,运行的时候再也不会跳出烦恼的对话框了.

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值