做一个简单的bad usb

作者: 原来是老王 | 来源:发表于2019-06-17 10:57 被阅读8次

    漏洞背景

    “BadUSB”是计算机安全领域的热门话题之一,该漏洞由Karsten Nohl和Jakob Lell共同发现,并在2014年的BlackHat安全大会上公布。 虽然已隔几年年,但还是有人在研究它,它的攻击方式也多种多样。

    介绍

    BadUSB原理

    在介绍BadUSB的原理之前,笔者在这里先介绍下BadUSB出现之前,利用HID(Human InterfaceDevice,是计算机直接与人交互的设备,例如键盘、鼠标等)进行攻击的两种类型。分别是”USB RUBBERDUCKY”和”Teensy”。

    TEENSY介绍

    攻击者在定制攻击设备时,会向USB设备中置入一个攻击芯片,此攻击芯片是一个非常小而且功能完整的单片机开发系统,它的名字叫TEENSY。通过TEENSY你可以模拟出一个键盘和鼠标,当你插入这个定制的USB设备时,电脑会识别为一个键盘,利用设备中的微处理器与存储空间和编程进去的攻击代码,就可以向主机发送控制命令,从而完全控制主机,无论自动播放是否开启,都可以成功。

    关于TEENSY,可以参考天融信阿尔法实验室的《HID攻击之TEENSY实战

    image

    USB RUBBER DUCKY介绍

    简称USB橡皮鸭,是最早的按键注入工具,通过嵌入式开发板实现,后来发展成为一个完全成熟的商业化按键注入攻击平台。它的原理同样是将USB设备模拟成为键盘,让电脑识别成为键盘,然后进行脚本模拟按键进行攻击。

    image

    这两种攻击方式,是在BadUSB公布之前,比较流行的两种HID攻击方式,缺陷在于要定制硬件设备,通用性比较差。但是BadUSB就不一样了,它是在“USB RUBBER DUCKY”和“Teensy”攻击方式的基础上用通用的USB设备(比如U盘)。

    U盘的内部构造

    image

    U盘由芯片控制器和闪存两部分组成,芯片控制器负责与PC的通讯和识别,闪存用来做数据存储;闪存中有一部分区域用来存放U盘的固件,它的作用类似于操作系统,控制软硬件交互;固件无法通过普通手段进行读取。

    BadUSB就是通过对U盘的固件进行逆向重新编程,相当于改写了U盘的操作系统而进行攻击的。

    USB协议漏洞

    为什么要重写固件呢?下面我们可以看看USB协议中存在的安全漏洞。

    现在的USB设备很多,比如音视频设备、摄像头等,因此要求系统提供最大的兼容性,甚至免驱;所以在设计USB标准的时候没有要求每个USB设备像网络设备那样占有一个唯一可识别的MAC地址让系统进行验证,而是允许一个USB设备具有多个输入输出设备的特征。这样就可以通过重写U盘固件,伪装成一个USB键盘,并通过虚拟键盘输入集成到U盘固件中的指令和代码而进行攻击。

    BadUSB利用代码分析

    笔者对KarstenNohl和Jakob Lell公布的代码进行简单的一个流程解析。

    image

    这样一个带有恶意代码的U盘就产生了,更详细的可以搜索Karsten Nohl 和 Jakob Lell公布的代码。

    0×01 制作过程

    好的废话咱们不多说了,直接开始吧~

    来看一下我们需要准备的材料吧

    微型usb开发板

    Arduino IDE

    笔记本一台

    启动Arduino IDE

    测试代码

    #include "DigiKeyboard.h"
    
    void setup() {
    DigiKeyboard.sendKeyStroke(0);
    DigiKeyboard.delay(3000);
    DigiKeyboard.sendKeyStroke(KEY_R, MOD_GUI_LEFT);
    DigiKeyboard.delay(500);
    DigiKeyboard.println("notepad");
    DigiKeyboard.delay(500);
    DigiKeyboard.print("Hello hack!");
    
    }
    
    void loop() {
    }
    
    

    先不要插入开发板点击上传按键


    出现这个时,插入开发板

    完成后会出现Thank you!的字样

    0×02 测试使用

    啊啊啊无法上传视频,就上传一个图片吧。

    相关文章

      网友评论

        本文标题:做一个简单的bad usb

        本文链接:https://www.haomeiwen.com/subject/llvpfctx.html