写程序取自己进程的AEP

测试程序功能

打印出自己进程的程序入口点地址.

结合OD载入程序,看到的入口点确实是0x004014f0, 说明程序入口点找到了

测试程序

[cpp] view plain copy

  1. /// @file exam_1_1.c
  2. #include <stdlib.h>
  3. #include <stdio.h>
  4. void fnGetProgEntry();
  5. int main(int agrc, char** argv)
  6. {
  7. fnGetProgEntry();
  8. printf("END, press any key to quit\n");
  9. getchar();
  10. return 0;
  11. }
  12. void fnGetProgEntry()
  13. {
  14. #define PE_SIGNTURE 0x4550 ///< "PE"
  15. int* pFileAddressOfNewHeader = NULL;
  16. int* pCOFFFileHeader = NULL;
  17. int* pAEP = NULL;
  18. const int iAddrPeImgBase = 0x400000;
  19. /// iOffsetX 为偏移
  20. /// iContent 为地址中的内容
  21. const int iOffsetFileAddressOfNewHeader = (16 * 4 - 4); ///< File address of new header 相对于DosHeader的偏移
  22. const int iOffsetAEPToFileAddressOfNewHeader = 0x28;
  23. int iContentFileAddressOfNewHeader = 0;
  24. int iPeSignature = 0;
  25. int iOffsetAddressOfEntryPoint = 0; ///< 程序入口点偏移地址
  26. do
  27. {
  28. pFileAddressOfNewHeader = (int*)(iAddrPeImgBase + iOffsetFileAddressOfNewHeader);
  29. iContentFileAddressOfNewHeader = *pFileAddressOfNewHeader; ///< iContentFileAddressOfNewHeader = 0xd0
  30. pCOFFFileHeader = (int*)(iAddrPeImgBase + iContentFileAddressOfNewHeader);
  31. iPeSignature = *pCOFFFileHeader;
  32. if (PE_SIGNTURE != iPeSignature)
  33. {
  34. printf("error pe file\n");
  35. }
  36. pAEP = (int*)((int)pCOFFFileHeader + iOffsetAEPToFileAddressOfNewHeader);
  37. iOffsetAddressOfEntryPoint = iAddrPeImgBase + *pAEP;
  38. printf("my address entry point is 0x%x\n", iOffsetAddressOfEntryPoint);
  39. } while (0);
  40. printf("END, press any key to quit\n");
  41. }

运行结果

http://blog.csdn.net/lostspeed/article/details/49506193

时间: 2024-10-31 22:02:58

写程序取自己进程的AEP的相关文章

Python程序中的进程操作-开启多进程(multiprocess.process)

目录 一.multiprocess模块 二.multiprocess.process模块 三.process模块介绍 3.1 方法介绍 3.2 属性介绍 3.3 在windows中使用process模块的注意事项 四.使用process模块创建进程 4.1 在Python中启动的第一个子进程 4.2 join方法 4.3 查看主进程和子进程的进程号 4.4 多个进程同时运行 4.5 多个进程同时运行,再谈join方法(1) 4.6 多个进程同时运行,再谈join方法(2) 4.7 通过继承Pro

110 python程序中的进程操作-开启多进程

之前我们已经了解了很多进程相关的理论知识,了解进程是什么应该不再困难了,刚刚我们已经了解了,运行中的程序就是一个进程.所有的进程都是通过它的父进程来创建的.因此,运行起来的python程序也是一个进程,那么我们也可以在程序中再创建进程.多个进程可以实现并发效果,也就是说,当我们的程序中存在多个进程的时候,在某些时候,就会让程序的执行速度变快.以我们之前所学的知识,并不能实现创建进程这个功能,所以我们就需要借助python中强大的模块. 一.multiprocess模块 仔细说来,multipro

用CIL写程序:写个函数做加法

前言: 上一篇文章小匹夫为CIL正名的篇幅比较多,反而忽略了写那篇文章初衷--即通过写CIL代码来熟悉它,了解它.那么既然有上一篇文章做基础(炮灰),想必各位对CIL的存在也就释然了,兴许也燃起了一点探索它,掌握它的欲望.那么小匹夫就继续扯一扯CIL,接下来的几篇文章也都以上一篇文章中的那个CIL实现的Hello Wolrd程序为基础,继续通过写CIL代码实现一些功能的方式来和各位探讨交流,同时也加深自己对CIL的掌握和印象. 人生就是做加法 "我的肩上搭着她得衣裳,我嗅着她留在衣服上的体香..

用CIL写程序:这个叫“慕容小匹夫”的类

前文回顾: <用CIL写程序:你好,沃尔德> <用CIL写程序:写个函数做加法> 前言: 今天是乙未羊年的第一天,小匹夫先在这里给各位看官拜个年了.不知道各位看官是否和匹夫一样,摸键盘的手都已经有点生疏了呢?所以,为了不忘却程序猿的使命,不冷落程序猿最好的伙伴--键盘.匹夫决定来写<用CIL写程序>的最新一篇文章.可是写什么主题呢?之前匹夫也介绍过CIL其实也是面向对象的,所以寻思着大过年的,不如就写一个类,一个用来抽象化小匹夫的类吧,既可以介绍下小匹夫,小匹夫也可以借

Java程序与其它进程的数据通信

Java程序中可以启动其他的应用程序,这种在Java中启动的进程称为子进程,启动子进程的Java程序称为父进程,其实这个父进程就是一个Java虚拟机1.在Java程序中可以用Process类的实例对象来表示子进程,子进程的标准输入和输出不再连接到键盘和显示器(也就是不再接收键盘输入,和显示器输 出),而是以管道流的形式连接到父进程的一个输出流和输入流对象上2.调用Process类的getOutputStream和getInputStream方法可以获得连接到子进程的输出流和输入流对象.子进程从标

【总结】学用python写程序

工作多年,因为项目需要,用过的编程语言不少了:c/c++.java.c#.汇编.vb.objective c.apple script.不过主要使用的还是c/c++,一方面是用得久了,习惯了.另一方面,思考问题的方式已经偏"底层"了,不想内存.不考虑指针,似乎就浑身冷汗,无法编程了.连带我在面试一些小朋友的时候也会不自觉的问一些底层的知识点.再有一方面,就是想要程序的运行效率更高一些,个人一直以写高效的(算法)程序为目标,而c/c++是除了汇编之外的,能写出的运行效率最高的编程语言--

【转】快速开发平台:大湿教我写程序(3)之自动补全(屌丝没有春天)篇

一.女神也爱玩撸码 "在么,亲." "在!在!有,有事么"(我真睡醒了么!垂涎了好久的女神呀!高中同学,高一向她表白,"我想找个170以上的",高二等我长到170了"我想找个175的",高三下血本买了双内增高"我喜欢178以上的,有安全感") 三分钟后.... "没事也可找我的."擦,我TM怎么这么不争气,不是发过誓等她主动跟我讲话的时候就送她一个字:滚! "有个网页不会做,你

激光雷达在首次上电程序自启动时进程死掉

现象:激光雷达在首次上电程序自启动时进程死掉 原因:程序开始设置输出强度数据为:true(断电后默认为:false),之后开始读取强度数据,但此时强度数据还未准备好,获取强度的函数里的某些值没有初始化,导致程序退出 处理:1.在读取强度数据之前延时 2.在构造函数中给报错的变量赋初值 经验: 1.在构造函数中对变量赋初值很重要,不要忘记,否则是个不定值. 2.写程序时要保子证函数的输出是正确的,或者说子函数能正确的运行,不会报错. 3.

【转载】学用python写程序

学用python写程序 工作多年,因为项目需要,用过的编程语言不少了:c/c++.java.c#.汇编.vb.objective c.apple script.不过主要使用的还是c/c++,一方面是用得久了,习惯了.另一方面,思考问题的方式已经偏“底层”了,不想内存.不考虑指针,似乎就浑身冷汗,无法编程了.连带我在面试一些小朋友的时候也会不自觉的问一些底层的知识点.再有一方面,就是想要程序的运行效率更高一些,个人一直以写高效的(算法)程序为目标,而c/c++是除了汇编之外的,能写出的运行效率最高