Hier werden die Unterschiede zwischen zwei Versionen der Seite angezeigt.
Nächste Überarbeitung | Vorherige Überarbeitung | ||
ctf:writeups:protokoll25042024 [2024/06/21 15:29] – angelegt faraway | ctf:writeups:protokoll25042024 [2024/06/21 16:10] (aktuell) – faraway | ||
---|---|---|---|
Zeile 1: | Zeile 1: | ||
=====Protokoll vom 25.04.2024===== | =====Protokoll vom 25.04.2024===== | ||
+ | |||
+ | ====gehackte Challenges==== | ||
+ | https:// | ||
+ | |||
+ | === picoCTF: Nice netcat === | ||
+ | Die Webseite verweist auf einen netcat-Befehl \\ | ||
+ | < | ||
+ | nc mercury.picoctf.net 35652 | ||
+ | </ | ||
+ | Die Ausführung der obigen Anweisung ergibt (auszugsweise) \\ | ||
+ | {{: | ||
+ | |||
+ | Schnell kommt der Verdacht auf, dass es sich hier um Ascii-Werte handeln könnte. | ||
+ | Ein kleines Script zur Übersetzung \\ | ||
+ | < | ||
+ | #! / | ||
+ | |||
+ | | ||
+ | |||
+ | flag = "" | ||
+ | for i in sys.argv[1: | ||
+ | flag += chr(int(i)) | ||
+ | |||
+ | | ||
+ | </ | ||
+ | Das Script wird für alle ausführbar gemacht mit \\ | ||
+ | < | ||
+ | chmod ugo+x translate | ||
+ | </ | ||
+ | Eine Ausführung mit xargs ergibt \\ | ||
+ | {{: | ||
+ | |||
+ | |||
+ | === picoCTF: Static ain't always noise === | ||
+ | Es wird eine Binary static gegeben. Mittels des strings-Befehls extrahiert man die Flag. | ||
+ | {{: | ||
+ | |||
+ | === picoCTF: Transformation === | ||
+ | Es wird eine Textdatei enc und ein kleines Script gegeben | ||
+ | < | ||
+ | enc '' | ||
+ | </ | ||
+ | Die Datei enc ist eine UTF-8 codierte Textdatei ohne Zeilenterminierung, | ||
+ | {{: | ||
+ | |||
+ | Die Datei enthält chinesische Schriftzeichen. \\ | ||
+ | {{: | ||
+ | |||
+ | UTF-8 ist ein multibyte Encoding, dass Schriftzeichen verschiedener Kulturen eine unterschiedliche Länge zuweist. Der Gedanke liegt nahe, dass das Script zur Verschlüsselung benutzt wurde. In dem Script wird die Flag in Blöcke von zwei nacheinanderfolgenden Buchstaben unterteilt, von denen der erste um 1 Byte geshiftet wird und auf den sich ergebenden Wert der Wert des zweiten Buchstaben aufaddiert wird. | ||
+ | Es gilt also dieses rückgängig zu machen. Dies wird von dem folgenden Script geleistet. | ||
+ | < | ||
+ | with open(" | ||
+ | encrypted=file.read() | ||
+ | |||
+ | flag = "" | ||
+ | for char in encrypted: | ||
+ | dchar1 = chr(ord(char) >> 8) | ||
+ | dchar2 = chr(ord(char) & 0x00ff) | ||
+ | flag += dchar1 | ||
+ | flag += dchar2 | ||
+ | print(flag) | ||
+ | </ | ||
+ | Die Ausgabe des Scriptes ist \\ | ||
+ | {{: | ||
+ | |||
+ | === picoCTF: Python Wrangling === | ||
+ | In dieser Aufgabe werden ein Python-Script, | ||
+ | Lösung:\\ | ||
+ | {{: |