抓了一下WinRAR广告弹窗过程,这下舒服了!
WinRAR大家都用过吧,抓下一款非常流行的广告过程压缩软件。
这软件好是弹窗好,但有一点让人不爽,下舒就是抓下每次打开它都要给我弹个广告窗口,非常的广告过程烦人。
(kimi:打钱!弹窗)
你要是下舒每天弹一下,或者不定期弹几下,抓下我还能忍受,广告过程每一次都弹广告,弹窗这简直没法忍。下舒
刚好最近在带着大家学习逆向,抓下本着学以致用的广告过程精神,今天就教大家如何把这个广告弹窗给去掉。弹窗
网上有很多去除的方法,但都是告诉你怎么做,却很少告诉大家原理。今天带着大家来看看针对这种广告弹窗问题该怎么处理,以后大家遇到其他软件弹窗,也可以迁移过去。
首先祭出一个工具spy++,这个工具可以用来查看Windows操作系统上所有程序的窗口信息,通过这个工具可以定位到这个广告窗口:
可以看到这个窗口的类名是RarReminder。
接下来我们去除广告弹窗的思路就来了:定位到Winrar程序中,具体是哪个位置在弹出这个窗口,然后将那里的逻辑给去除掉。
接下来上另一个神器:APImonitor,顾名思义,这个工具可以监控指定进程的API调用。
(PS:这个工具是通过HOOK来实现对相关API函数的调用监控的)
在Windows操作系统上,窗口的创建是通过一个叫CreateWindow系列的Win32 API进行的。我们把相关的函数勾选上,表示要监控这些函数的调用。接下来通过这个工具来启动WinRAR程序。
WinRAR进程所有创建窗口的行为都会被这个工具给记录下来了:
很容易可以找到上面那个广告窗口RarReminder的创建记录。
在下面的调用堆栈面板中,可以找到具体调用CreateWindow函数的地方,偏移量是0xaa56d。
接下来请出第三个工具,逆向分析神器IDA来看一看WinRAR.exe这个可执行程序中,在偏移0xaa56d的位置,上面那个创建广告窗口的地方。
好了,位置找到了,要去掉这个弹窗就很简单了,直接把这个函数的调用指令给去掉。
怎么去掉呢?
在x86平台上,调用函数是一条call指令,直接把这条call指令对应的16进制CPU机器码换成nop指令对应的0x90就可以了。
这是这条call指令原来的机器码(蓝色选中部分):
替换后:
好了,现在保存WinRAR.exe文件,再次打开压缩包文件,广告弹窗没了!
非常好用的一个小技巧,大家如果有其他软件也有烦人的弹窗,也可以试试这招哦~
- ·女排队长再次换人!蔡斌临时被顶替,或是下课前兆?
- ·44+9!29+12!全联盟备受质疑,他逆天改命,湖人打掘金一雪前耻
- ·44+9!29+12!全联盟备受质疑,他逆天改命,湖人打掘金一雪前耻
- ·14中13怒砍29+8!2米01迷你内线打爆王哲林,上海防不住他难进4强
- ·苏州市新时代工商管理企业家联合会“周日交流会”举行
- ·范增的艺林佳话成了笑话!
- ·冯提莫又火了!成都街头现场唱歌,涌入30多万人直播破百万赞
- ·投降的机会都不给!法军先头部队刚到乌克兰,就已经伤亡近半!
- ·嫦娥六号顺利回归,欧洲这下尴尬了,月球土壤到底还要不要?
- ·港律师首驻场执业:北上更多机会
- ·杭州滨江地产降薪35%
- ·惨败广东20分的赛后,朱俊龙为什么要专门赶过来向杜锋道歉?
- ·喜茶新品被指擦边!网友:根本念不出口……
- ·小猪:瓜迪奥拉的风格毁了拜仁和德国队,我们忘记了战斗精神
- ·重看童年热剧,竟发现如此多虎狼之词
- ·吃人血馒头?B站突现大量直播,名字均为《XX患癌停药,XX努力再努力》