陈硕的Blog

吾尝终日而思矣,不如须臾之所学也。吾尝跂而望矣,不如登高之博见也。……君子生非异也,善假于物也。

原创 地址空间布局随机化(Address Space Layout Randomization)与缓冲区溢出攻击收藏

新一篇: 面试题1:连续整数之和为1000的共有几组? | 旧一篇: 一道Google top coder的850分例题及解答

记得以前在Linux下做缓冲区溢出攻击的实验,用了两台机器,一台装RedHat 8.0,另一台装RedHat 9.0,发现一个奇怪的现象。RedHat 8.0的栈基地址是固定的,而RedHat 9.0的栈基地址是浮动的。比如对于下面这个程序,RedHat 8.0每次运行的输出是相同的,而RedHat 9.0则不同。

int main()
{
    char buf[256];
    printf("0X%X\n", buf);
    gets(buf);
}

明显感觉到,由于栈基地址会变化,那种最普通的缓冲区溢出攻击(传一段shellcode给gets()函数)在RedHat 9.0下较难成功。(在RedHat 8.0下倒是一试一个准。)当时也没太在意,觉得这可能是RedHat 9.0增强系统安全性的一个做法。

今天偶然发现,这种做法叫做 address space layout randomization,不仅随机化栈地址,还可以随机化动态链接库(比如libc)的基地址(应对return-to-libc攻击)和mmap的地址。

我没有进一步深究,据说OpenBSD、Linux、Vista都有实现这一技术,以下是一些参考地址。

http://pax.grsecurity.net/docs/aslr.txt
http://blogs.msdn.com/michael_howard/archive/2006/05/26/608315.aspx
http://www.csc.ncsu.edu/faculty/junxu/software/aslp/
http://www.stanford.edu/~blp/papers/asrandom.pdf

发表于 @ 2006年08月11日 17:13:00|评论(loading...)|编辑

新一篇: 面试题1:连续整数之和为1000的共有几组? | 旧一篇: 一道Google top coder的850分例题及解答

评论

#myan 发表于2006-08-14 08:25:00  IP: 58.49.250.*
四个月不开张,开张写四句。
#Solstice 发表于2006-08-14 13:12:00  IP: 207.46.89.*
见笑,见笑。
发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © 陈硕