OD 实验(四) - 去除 NAG 窗口的几种方法
程序:
运行

弹出一个窗口,说要注册
点击确定,到主窗口

关闭主窗口

然后弹出提醒注册的对话框
逆向程序
用 OD 打开程序

GetModuleHandleA 获取程序模块的句柄,程序在内存中的基址
内存中的一个模块代表一个可执行文件进程所需要的所有代码、数据、资源的集合
GetModuleHandleA 获取到的值放在 EAX 寄存器中
接下来的
mov dword ptr ds:[0x40311C],eax
把 EAX 的值赋给地址为 0x40311C 上

即把 00400000 放到地址 0x40311C 上
接下来,cmp 指令比较 eax 和 0 的关系

如果 eax 等于 0 的话,je 将跳过第一个 NAG弹窗
eax 为 0 的话,GetModuleHandleA 的返回值就为 0,GetModuleHandleA 就是没有句柄
可以把 je 改为 jmp 实现无条件跳转

第一个窗口也可以用 nop 填充来跳过第一个 NAG 窗口

选定区域
右键 -> 二进制 -> 用 NOP 填充

一个 NOP 相当于一个字节
还有一种方法

MessageBoxA 函数的第一个参数为 hOwner
hOwner 为该消息框的父窗口句柄,如果此参数为 NULL,则该消息框没有拥有父窗口
把 push 0x0 改为 push 0x1

1 不可能是一个句柄的值,所以这是一个不存在的句柄,则这个 MessageBoxA 也是不存在的
也可以通过修改 PE 文件头来去除 NAG 窗口

程序从地址 00401000 处开始
GetModuleHandleA 获取到的基地址为 00400000

所以地址 00400000 到地址 00401000 存放程序的文件头
可以通过修改程序的初始地址来跳过 NAG 窗口

点击 m,快捷键为 Alt+M,进入显示内存的窗口

00400000 开始为 PE 文件头,大小为 00001000
00401000 开始为代码块,00402000 开始为数据块
双击 PE 文件头这行,查看文件头的内容

第一列为地址,第二列为在内存中的指令形式,第三列为方便阅读的指令形式
例如第二行的 9000,是低地址 09 放前面,高地址 00 放后面
内存中的存放形式与现实中的读数是倒过来的

这个地方是 PE 结构的开始,是双字类型
C0 为指向 PE 头的偏移地址,相对于基地址偏移,即为 00400000 的偏移,地址为 004000C0
看一下地址为 004000C0 的地方

这个就是 PE 头,以 PE 的 ASCII 码开头

这个地方是程序的入口地址,这里的值为 0x1000,地址即为 00401000
把入口地址修改为 MessageBoxA 之后

地址为 00401024

在这里按 Ctrl+G 跟随表达式

输入设置程序入口地址的地址

接下来修改数值

把这个修改为 24,即为 1024
接下来保存文件
右键 -> 复制到可执行文件

右键 -> 备份 -> 保存数据到文件
运行一下保存的程序

没有弹第一个 NAG 窗口,而是直接进入主窗口
关闭主窗口,将弹出第二个 NAG 窗口

OD 实验(四) - 去除 NAG 窗口的几种方法的更多相关文章
- OD调试4--绕过nag窗口
先看一下程序的运行情况 先跳出了一个nag窗口 点确定 又跳出了一个NAG窗口,这是一些程序编写的时候常用的方法,设法让你购买正版软件, 于是今天呢,学会了四种绕过NAG的方法 我们先用OD加载进入这 ...
- OD调试4--去除NAG窗口
OD调试4--去除NAG窗口 nag本意是烦人的意思,nag窗口是软件设计者用来时不时提醒用户购买正版的警告窗口.软件设计者可能认为当用户忍受不了试用版中的这些烦人的窗口时,就会考虑购买正式版本. 一 ...
- python3 打开页面后多窗口处理三种方法
多窗口处理三种方法 导包,实例化浏览器from selenium import webdriver fx=webdriver.Firefox()方法一fx.switch_to.window(fx.wi ...
- Windows 10 应用创建模糊背景窗口的三种方法
原文 Windows 10 应用创建模糊背景窗口的三种方法 现代的操作系统中创建一张图片的高斯模糊效果非常容易,不过如果要在窗口中获得模糊支持就需要操作系统的原生支持了.iOS/Mac 和 Windo ...
- python3 selenium 切换窗口的几种方法
第一种方法: 使用场景: 打开多个窗口,需要定位到新打开的窗口 使用方法: # 获取打开的多个窗口句柄windows = driver.window_handles# 切换到当前最新打开的窗口driv ...
- Response.Redirect 打开新窗口的两种方法
一般情况下,Response.Redirect 方法是在服务器端进行转向,因此,除非使用 Response.Write("<script>window.location='htt ...
- selenium 切换窗口的几种方法
第一种方法: 使用场景: 打开多个窗口,需要定位到新打开的窗口 使用方法: # 获取打开的多个窗口句柄 windows = driver.window_handles # 切换到当前最新打开的窗口 d ...
- C#中去除字符串空格的三种方法
static void Main() { //demo1 除去空格,提取出各个单词 string s = "a b c"; string[] word = s.Split(new ...
- Delphi中拖动无边框窗口的5种方法
1.MouseMove事件中加入: // ReleaseCapture;// Perform(WM_SYSCOMMAND, $F017 , 0); 2.MouseDown事件中加入: // POSTM ...
随机推荐
- keras系列︱seq2seq系列相关实现与案例(feedback、peek、attention类型)
之前在看<Semi-supervised Sequence Learning>这篇文章的时候对seq2seq半监督的方式做文本分类的方式产生了一定兴趣,于是开始简单研究了seq2seq.先 ...
- ubuntu安装 tensorflow GPU
安装支持GPU的tensorflow前提是正确安装好了 CUDA 和 cuDNN. CUDA 和 cuDNN的安装见 Nvidia 官网和各种安装教程,应该很容易,重点是要选准了支持自己GPU的 CU ...
- 关于C++一些面试题目的总结
众所周知,在找工作时笔试题目往往对C++有大量考察,现在我们总结一些C++中比较重要而且可能会考到的知识. 1.判断一下A,B,C,D四个表达式是否正确. int a = 4: A:a += (a + ...
- ssm+PageHelper实现分页查询
通过搭建ssm框架,然后通过mybatis的分页插件pagehelp进行分页查询.源码:https://gitee.com/smfx1314/pagehelper 看一下项目结构: 首先创建一个mav ...
- bzoj 5334 数学计算
bzoj 5334 数学计算 开始想直接模拟过程做,但模数 \(M\) 不一定为质数,若没有逆元就 \(fAKe\) 掉了. 注意到操作 \(2\) 是删除对应的操作 \(1\) ,相当于只有 \(1 ...
- BZOJ1014 JSOI2008 火星人prefix 【非旋转Treap】*
BZOJ1014 JSOI2008 火星人prefix Description 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符 ...
- 【模板】NTT
NTT模板 #include<bits/stdc++.h> using namespace std; #define LL long long const int MAXL=22; con ...
- selenium python实例脚本1
#!/usr/local/bin/python3 # coding=utf-8 #统一编码from selenium import webdriverfrom time import sleep#im ...
- C# winform中自定义用户控件 然后在页面中调用用户控件的事件
下面是用户控件的代码: using System; using System.Collections.Generic; using System.ComponentModel; using Syste ...
- wordpress上传文件,插件无法建立目录(根本原因解决)
刚建立的wp网站经常遇到上传图片或者下载插件“无法建立目录”的问题,肯定是权限的问题,网上大部分解决方案都是把uploads或者 plugins权限手动改成777, 有一部分人成功了,有一部分没成功, ...