zoukankan      html  css  js  c++  java
  • 20199306《Linux内核原理与分析》第十一周作业

    ShellShock攻击实验

    什么是ShellShock?

    • Shellshock,又称Bashdoor,是在Unix中广泛使用的Bash shell中的一个安全漏洞,首次于2014年9月24日公开。许多互联网守护进程,如网页服务器,使用bash来处理某些命令,从而允许攻击者在易受攻击的Bash版本上执行任意代码。这可使攻击者在未授权的情况下访问计算机系统。

    实验步骤

    1.安装和搭建环境

    #下载
    sudo su 
    $ wget http://labfile.oss.aliyuncs.com/bash-4.1.tar.gz
    #安装
    $ tar xf bash-4.1.tar.gz
    $ cd bash-4.1
    $ ./configure
    $ make & make install
    #链接
    $ rm /bin/bash
    $ ln -s /usr/local/bin/bash /bin/bash
    


    2.检测漏洞

    $ exit
    $ env x='() { :; }; echo vulnerable' bash -c "echo this is a test"
    

    输出vulnerable的话,说明bash有漏洞。
    最后,让/bin/sh 指向/bin/bash.

    $ sudo ln -sf /bin/bash /bin/sh
    

    3.攻击Set-UID程序

    • Set-UID 是Unix系统中的一个重要的安全机制。当一个Set-UID程序运行的时候,它被假设为具有拥有者的权限。如果程序的拥有者是root,那么任何人运行这个程序时都会获得程序拥有者的权限。Set-UID允许我们做许多很有趣的事情,但是不幸的是,它也是很多坏事情的罪魁祸首。

    在 /home/shiyanlou 目录下新建一个 shock.c 文件

    编译这段代码,并设置其为Set-UID程序,保证它的所有者是root。

    $ sudo su
    $ gcc -o shock shock.c
    $ chmod u+s shock
    

    :运行外部函数。real UID是标记谁调用了该可执行文件;effective UID表示该可执行程序所具有的权限的用户;默认情况下real UID和effective UID一样,但是当使用了setUID之后,两者有可能不一样。例如passwd程序,当你执行这个程序的时候,它的real UID就是调用passwd的用户,这个用户可能是root,也可能是任何普通用户;但是它的effective UID是root,只有这样passwd程序才能修改/etc/passwd文件。

    我们注意到这里使用了setuid(geteuid()) 来使real uid = effective uid。

    • 如果 setuid(geteuid()) 语句被去掉了,再试试看攻击,我们还能够拿到权限么?
    $ sudo su
    $ gcc -o shock1 shock.c
    $ chmod u+s sh0ck
    $ ls -il shock1
    $ exit
    $ ./shock1
    

    失败了!这就说明如果 real uid 和 effective uid 相同的话,定义在环境变量中的内容在该程序内有效,那样shellshock漏洞就能够被利用了。但是如果两个 uid 不同的话,环境变量失效,就无法发动攻击了

    实验总结

    因为上述那一行判断逻辑导致了两者的不同,primode即私有模式,要求real uid 与 effective uid保持一致。对比两次攻击结果,思考是什么导致的攻击结果的改变呢?这就说明如果 real uid 和 effective uid 相同的话,定义在环境变量中的内容在该程序内有效,那样shellshock漏洞就能够被利用了。但是如果两个uid不同的话,环境变量失效,就无法发动攻击了。

  • 相关阅读:
    文件处理seek以及修改内容的两种方式
    三元表达式、列表推导式、生成器表达式、递归、匿名函数、内置函数
    MySQL逻辑查询语句执行顺序
    函数基础
    迭代器、生成器、面向过程编程
    3 函数
    文件处理
    字符编码
    2 数据类型、字符编码、文件处理
    转载文章之提供给开发者 10 款最好的 Python IDE
  • 原文地址:https://www.cnblogs.com/Huyiming/p/11940333.html
Copyright © 2011-2022 走看看