-
-
[讨论]在win10和winxp系统下相同程序呈现的不同领空问题
-
发表于:
2024-7-4 23:24
2740
-
[讨论]在win10和winxp系统下相同程序呈现的不同领空问题
在win7和win10系统下应用程序显示的领空不同问题
我看过很多讲解逆向的视频,也搜了很多资料,但是没有人提这个问题,这对于新手小白用win10及以上的系统来破解会造成很大麻烦。下面具体讲解问题:
在这里我以下面程序为例:
该程序需要输入一个字符串点击破解
winxp系统程序下messageboxw断点,发现系统断在了系统领空:
在这里我们进行回溯,发现每一个return跳出call都是在系统领空,这里就只展示第一个call返回的情况:
当我们一直回溯到程序领空后,发现关键跳转正好在这个call上面:
这时大家是不是觉得破解很简单,只要回到程序领空往上走就行。
好了,上面都是基础,这时候我们在win10系统上面重复做一样的操作:
同样断点断在系统领空,这时候我们开始回溯,发现第一个return就来到了程序领空:
小伙伴们这里就要注意了,程序来到了程序领空,但是我们往上看却并不是关键跳转所在,我们只能继续回溯,发现一直在程序领空,回溯了好几次后才找到关键call以及关键跳转:
这里就有一个重要问题:在winxp下我们可以直接了断的在返回程序领空后找到关键跳转,而在win10我们下断点返回程序领空后却不是关键call所在,还得继续回溯,对于汇编不了解或者是复杂代码的破解难度应该算是巨大提升了吧,有大佬可以讲解这个问题吗,本人小白一枚,最近发现这个问题感觉win10对于破解并不友好。
或许是我对程序领空和系统领空理解有问题,不过我看很多都是按这套理论讲解的,有大佬可以对这一现象进行解释吗?
注:我一开始以为是工具的问题,这里用的是ollydb,后来也用x32dbg试过发现是一样的。
[招生]科锐逆向工程师培训(2024年11月15日实地,远程教学同时开班, 第51期)