逆向入门之路2 Hello World (论装逼准备工作的重要性)

大部分的编程语言都是从hello world开始,我们的逆向学习也从Hello World开始!

先写一个程序:

#include
<windows.h>

int
main() {

MessageBoxA(0, "world", "tip", 0);

}

没错,就是这么短小~~~~

编译运行后的结果是这样的:

然后我们删掉源代码,没错,就是删掉源代码~~~

我们要在只有二进制文件的情况下把他改造成一个hello world程序。

打开萌萌的OD,载入程序(这段不懂没关系,反正就没打算让这么早懂~~~)

然后,我们使用F8单步运行,直到弹出消息框。

当执行到这一句的时候,消息框弹出了,然后我们在这一句使用F2下个断点,Ctrl+F2重新运行程序,F9直接运行到断点处,然后F7跟进调用内部:

于是,我们找到消息框弹出的位置了,记录下这个地址01061000,然后我们双击调用MessageBoxA的语句,复制下语句:call dword ptr ds:[0x1062034],存下来。

然后我们找一段程序未用到的内存区域,一般是到程序的末尾处寻找:

我们找到01061BE0这个空闲区域,然后,我们写一些数据:

转到内存窗口:

选定一段区域,按下Ctrl+E编辑:

我们在这里填充"SkyFire Add This MessageBox"

确定。然后我们用相同的方法在下面一块空闲区域填写"Hello World",这时,我们的汇编窗口也会跟着改变:

我们在汇编窗口选择一块空闲区域,这里选择01061C1D:

我们在这里编写我们的汇编代码,我们也要写一个MessageBox,首先将四个参数入栈:

参数从右向左入栈,所以依次进入的是,MB_OK(按钮类型),title(标题),message(消息内容),ParentWnd(父窗口)。

然后调用MessageBoxA,使用前面记录的语句。

我们只是在这里实现了窗口,但是却无法调用,所以我们得回到调用原窗口的地方:010611DA,将此处的语句call 01061000改为call 01061C1D,这样程序就能成功跳转到我们写的函数中,我们对我们的程序改写一下,让他依然能回到正常轨道:

然后我们将程序保存一下:

然后保存文件:

保存为TestHelloWorld2.exe,运行一下试试:

OMGD,装逼失败~~~~

在过程上是没有问题的,猜想应该是这个原因:VS2015在编译时默认开启了DEP(数据执行保护)和ASLR(随机地址加载,导致我们写的地址都无效了,心塞塞……)

关于如何分析开了DEP和ASLR的程序,等学到再说~~~~

时间: 2024-08-24 02:41:53

逆向入门之路2 Hello World (论装逼准备工作的重要性)的相关文章

小猪的Android入门之路 Day 8 part 2

小猪的Android入门之路 Day 8 part 2 Android网络编程浅析--Android访问网络资源 --转载请注明出处:coder-pig 本节引言: 在part 1中我们学习了网络交互中用得较多的xml文件的相关概念,以及在Android中常用的 解析XML三种不同形式,分别SAX,DOM,Pull三种不同的解析方式;而在part 2中我们将会 讲解我们的应用如何去获取网络上的资源,分别是图片,HTML代码,XML代码和JSON数据; 好了,废话就这么多,开始本节的课程吧!从这p

android逆向入门及工具下载

本文所用到的工具下载: 链接:http://pan.baidu.com/s/1i3uw4NN 密码:8hz5 最近在研究如何逆向android的app,于是就有了这篇android逆向入门的总结回馈互联网. 由于Android的.apk文件实际上就是一个zip文件,修改文件后缀后直接可以打开,效果如下图所示: 里面包含了的文件有: META-INF:这个文件夹是用于保存签名文件,确保包的完整性的 res:apk所要用的资源文件,都是原封不动地保存,我们可以直接提取出来,做汉化时就可以直接阅读st

小猪的Android入门之路 Day 8 part 4

小猪的Android入门之路 Day 8 part 4 Android网络编程浅析--Android网络数据的上传 --转载请注明出处:coder-pig 本节引言: 在part 3中我们已经学习了Android网络数据的下载,难点是多线程断点续传下载; 有下载,当然也有上传啦,本节就来研究下Android中的网络数据的上传! 1.使用GET或者Post方式上传数据给服务器 2.使用开源框架HttpClient上传数据到服务区 3.发送xml数据给服务器 4.通过Http协议上传文件 5.Web

小猪的Android入门之路 Day 4 - part 4

小猪的Android入门之路 Day 4 - part 4 Android事件处理机制之--事件处理机制拾遗 ------------转载请注明出处--coder-pig 本节引言: 在前面三个部分中,对于android的事件处理机制的学习已经学得七七八八了, 基于监听与回调的时间处理机制,以及使用Handler传递信息的机制都已经学了; 在最后这个部分中会对一些小的知识点进行补充,比如触摸事件的两种形式, Configuration类以及异步任务AsyncTask进行讲解,好了,开始本节的课程

小猪的Android入门之路 Day 3 - part 1

小猪的Android入门之路 Day 2 各种UI组件的学习 Part 1 本节引言: 在上一节中,我们初次体验了Android开发的一个流程,开发了一个简单的电话拨号器; 然后又学习了android的六大布局,界面无非是由布局 + 控件构成;布局都学了,剩下的 当然是控件啦,不过Android 所提供的UI组件还是比较丰富的;我们不求掌握他们的全部 用法,只需要了解一些基本的用法,等需要时再查资料就可以了!当然,内容是以android UI 组件实例大全为依托的,因为内容较多,所以需要分成几个

小猪的Android入门之路 Day 7 part 4

小猪的Android入门之路 Day 7 part 4 Android的数据存储与访问之--ContentProvider(内容提供者)                                   ---转载请注明出处:coder-pig 本节引言: 在前面的学习中,我们已经学习了一些存储数据的方式,而这些都是可以共享的,比如文件,我们可以把操作 模式设置为Context.MODE_WORLD_READABLE 或Context.MODE_WORLD_WRITEABLE,其他应用 就可以

小猪的Android入门之路 Day 5 - part 1

小猪的Android入门之路 Day 5 - part 1 基本程序单元:Activity(活动) ------------转载请注明出处--coder-pig 本节引言: 经过前面的学习,我们已经可以开发出一个自定义简单UI界面以及具有简单逻辑业务的App了, 不过都是在一个界面上完成的,而现在大部分的app都是拥有多个界面的,所以我们有必要继续深入地 学习,而这些所谓的界面,窗口,在Android我们把他们叫做Activity(活动),他也是Android四大组件的其中 一个,是基本的程序单

小猪的Android入门之路 Day 4 - part 3

小猪的Android入门之路 Day 4 - part 3 Android事件处理机制之--Handler消息传递机制 ------------转载请注明出处--coder-pig 本节引言: 在前面两个部分中,我们对于android的两种事件处理机制:监听与回调进行了深入的学习; 貌似就学完android的事件处理机制了,其实这两个仅仅是发生了触摸啊之类做出的事件响应; 而今天这一Part要讲的是修改Activity中的UI组件时发生一些信息传递;相信大家都知道,我们只能够 主线程中去修改Ac

小猪的Android入门之路 Day 4 - part 1

小猪的Android入门之路 Day 4 - part 1 Android事件处理机制之--基于监听的事件处理机制 本节引言: 在开始本个章节前,我们先回顾下,现在我们已经知道了android的一些相关背景,一些常用的UI组件, 六大布局,现在的我们已经可以做出一个简单的app界面了,下一步就是逻辑与业务的实现了;在前面 的例子中我们曾经看到过setXXXListener这些东东,这个就是android 的事件处理,而这个方法是基于监听的 Android为我们提供了两套功能强大的事件处理机制: