我们知道程序在每次运行的时候地址都是不一样的,linux之所以有这样的设计也许是为了安全性考虑,不利于黑客的攻击。
我们看一个简单的程序:
#include
#include
int main(int argc, char* argv[])
{
int first = 0;
int *p = malloc(1024);
printf("p=%pn", p);
return 0;
}
显然程序每次运行的地址都不一样!
那么有没有办法让相同程序每次运行的地址都一样呢?
看到这里你也许会问为什么让程序每次运行的地址都一样,这不违背OS设计的初衷了吗?是的,这的确违背 linux 内核设计的初衷。但是实际项目中难免不会遇到奇葩的需求,比如有些app由于历史的原因需要运行在指定地址上,那这时候就需要把地址空间随机化关掉。再比如遇到随机地址crash问题也可以用这种方法debug。
废话少说,我们看下地址空间随机化关掉的方法。
echo 0> /proc/sys/kernel/randomize_va_space
or
sudo sysctl -w kernel.randomize_va_space=0
关掉后我们看下该程序的测试结果:
哇!地址一样!
阅读全文