关于访问其他程序变量的尝试
突然有个想法,如果知道别的程序存储的内存地址,就可以修改他的变量
之后我做了个试验:
A程序创建int变量num,并不断输出:
- C/C++ code
#include "iostream"using namespace std;int main(int argc, char* argv[]){ int num = 100; while(true) { cout<<num<<'\t'<<&num<<endl; system("pause"); } return 0;}先启动A程序,之后B程序创建一指针指向A程序中num的地址,并修改之。在我调试时,A中num的地址是:0x0012ff44
所以B程序代码写成了:
- C/C++ code
int main(int argc, char* argv[]){ int *p = (int*)0x0012ff44; *p = 200; system("pause"); return 0;}可是修改之后,A程序中的输出还是100,并没有变化,请问是什么原因呢?
PS:在VC6上调试的
[解决办法]
每个进程都有自己的地址空间
[解决办法]
把自己注入到目标进程执行http://rlib.googlecode.com/svn/Examples/Loader/
[解决办法]
Widnows平台下就去看看《Windows核心编程》