雪城大学信息安全讲义 4.5

简介: 5 堆或 BSS 的缓冲区溢出堆或 BSS 的内容字符串常量全局变量静态变量动态分配的内存示例:覆盖文件指针/* The following variables are stored in t...

5 堆或 BSS 的缓冲区溢出

  • 堆或 BSS 的内容

    • 字符串常量
    • 全局变量
    • 静态变量
    • 动态分配的内存
  • 示例:覆盖文件指针

    /* The following variables are stored in the BSS region */ 
    static char buf[BUFSIZE], *tmpfile;
    
    tmpfile = "/tmp/vulprog.tmp"; 
    gets(buf); /* buffer overflow can happen here */
    
    ... Open tmpfile, and write to it ...

    • Set-UID 程序的文件指针指向了/tmp/vulprog.tmp
    • 程序需要在执行期间,使用用户输入写入文件、
    • 如果我们可以使文件指针指向/etc/shadow,我们就可以使程序写入它。
    • 我们可以使用缓冲区溢出来改变变量tmpfile的内存。通常,它指向了/tmp/vluprog.tmp字符串。使用缓冲区溢出漏洞,我们就可以将tmpfile的内容修改为0x903040,它就是字符串/etc/shadow的地址。之后,当程序使用tmpfile变量打开文件来写入时,它实际上打开了shadow文件。
    • 如何寻找/etc/shadow
      • 我们可将字符串作为参数传入程序,这样字符串/etc/shadow就储存在内存中。我们现在需要猜测它在哪里。
  • 示例:覆盖函数指针:

    int main(int argc, char **argv) { 
        static char buf[16]; /* in BSS */ 
        static int (*funcptr)(const char *str); /* in BSS */
    
        funcptr = (int (*)(const char *str))goodfunc;
    
        /* We can cause buffer overflow here */ 
        strncpy(buf, argv[1], strlen(argv[1]));
    
        (void)(*funcptr)(argv[2]); 
        return 0;
    }
    /* This is what funcptr would point to if we didn’t overflow it */ 
    int goodfunc(const char *str) { 
        ... ... 
    }

    • 函数指针(例如int (*funcptr)(char *str))允许程序员动态修改被调用的函数。我们可以通过覆盖它的地址来覆盖函数指针,使之在执行时,它调用我们指向的函数。
    • argv[]方式:将 Shellcode 储存在程序的参数中。这会使 Shellcode 储存在栈上。之后我们需要猜测它的地址(就像我们在栈溢出中那样)。这个方式需要可执行的栈。
    • 堆方式:将 Shellcode 储存在堆或 BSS 中(通过使用溢出)。之后我们需要猜测它的地址,并将估算的地址赋给函数指针。这个方式需要可执行的堆(比可执行的栈概率更大)。
  • 函数指针
    • 函数指针可以通过多种手段储存在堆或 BSS 中。这不需要由程序员定义。
    • 如果程序调用了atexit,函数指针就会由atexit储存在堆上,并且会在程序终止前调用。
    • svc/rpc注册函数(librpc, libnsl以及其他)将回调函数储存在堆上。
  • 其它示例
    • BSDIcrontab基于堆的溢出:长文件名的传递会溢出静态缓冲区。在内存中的缓冲区上面,我们拥有pwd结构,它储存用户名、密码、UID、GID,以及其他。通过覆盖pwd的 UID/GID 字段,我们可以修改权限,使crond使用它执行我们的crontab(只要他尝试执行我们的crontab)。这个脚本之后可以产生 Suid Root Shell,因为我们的脚本会使用 UID/GID 0 来执行。

参考

  1. P. J. Salzman. Memory Layout And The Stack. In Book Using GNU’s GDB Debugger. URL: http://dirac.org/linux/gdb/02a-Memory_Layout_And_The_Stack.php.
相关文章
|
算法
孜孜不倦,上下求索——悼念原复旦大学计算机学院朱洪教授
上海交通大学软件学院副教授李停舟发微博称,原复旦大学计算机系教授朱洪1月27日逝世。朱洪教授是我国知名算法理论专家,也是复旦大学计算机科学技术学院40多年发展的亲历者和建设者。本文将朱洪教授在复旦工作的经历进行编辑,以念逝者。
3475 0
|
人工智能 自动驾驶 数据安全/隐私保护
观点|来自UCL实验室大佬的学术生涯避雷指南
  Stephen Fleming 在牛津大学读取心理学与生理学硕士之后,又在伦敦大学学院获得了认识神经心理学的博士学位。硕博时期获得了多个奖项和名誉的 Stephen Fleming 决定继续从事学术研究,在伦敦大学学院创立了元认知实验室,领导人类意识、元认知、决策方面的研究。   回顾实验室建立近三年来的种种,Stephen Fleming 感慨良多。他把自己的感受、反思以及对后来者的建议写成了博客,AI科技评论对博客内容编译如下。
95 0
|
机器学习/深度学习 Web App开发 人工智能
邢波任校长的大学迎来机器学习鼻祖:Michael Jordan加盟MBZUAI任荣誉教授
邢波任校长的大学迎来机器学习鼻祖:Michael Jordan加盟MBZUAI任荣誉教授
194 0
邢波任校长的大学迎来机器学习鼻祖:Michael Jordan加盟MBZUAI任荣誉教授
|
机器学习/深度学习 人工智能 自然语言处理
高中生福利!清华姚班首发高中AI教材,姚期智院士主编,秋季出版
高中生福利!清华姚班首发高中AI教材,姚期智院士主编,秋季出版
366 0
|
安全
4月3日 尤金.卡巴斯基在北大精彩演讲
4月3日,国际信息安全领域的顶级专家之一、卡巴斯基实验室创始人——尤金•卡巴斯基登上北京大学百周年纪念讲堂,发表了旨为“恶意软件与恶意软件体系的演变”的主题演讲,而精彩绝伦的演讲博得北大学子阵阵掌声,同时,卡巴斯基先生在现场亲手启动了信息安全进校园的仪式,从而标志着卡巴斯基信息安全校园推广活动藉此拉开大幕。
965 0
|
大数据 云计算
“筑梦未来,起航云栖”2018阿里云大学数据科学夏令营活动圆满结束
本次夏令营旨在基于大数据学院学生已有知识与技能,聚焦大数据、云计算、人工智能领域专业知识,通过阿里云先进的云上计算实验资源与阿里资深工程师现场辅导、面对面的阿里师兄交流、阿里HR现场答疑、园区与企业参观等环节,从理论到应用、从学校到企业、从线上到线下使学生深入地理解所学专业知识的应用场景及应用技巧,让同学们更近距离地体验到最前沿的科技,深刻体验阿里独特的文化和职业成长环境。
4013 0
|
人工智能 大数据 量子技术
沈向洋博士致2018届毕业生的公开信:计算机科学的三堂人生课
上周五,沈向洋博士在美国华盛顿大学计算机科学与工程学院的年度毕业典礼致辞,他回顾了早年求学时候的经历,分享了从量子计算、人工智能和混合现实三种技术中总结出的三种人生经验。
1193 0