Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische...

31
Einf¨ uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian Esperer, CDA [email protected] 21. Juni 2008 HC, CDA CTF – Capture the Flag

Transcript of Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische...

Page 1: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

CTF – Capture the Flag

Hans-Christian Esperer, [email protected]

21. Juni 2008

HC, CDA CTF – Capture the Flag

Page 2: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

ToC

1 Einfuhrung – Wtf ist ein CTF?Versuch einer DefinitionIllustration. . .Ablauf

2 Klassische SicherheitsluckenUrsachenSQL injectionBuffer overflowSUID

3 DiskussionRelevanz in der heutigen ZeitPunktesystemAdvisories

4 Ein eigener CTFWarum ein eigener CTF?Dienste schreibenGameserverProbleme

HC, CDA CTF – Capture the Flag

Page 3: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Versuch einer DefinitionIllustration. . .Ablauf

CTF in der IT-Sicherheit

Wettbewerb

2 oder mehr Teams

Klassische Sicherheitlucken

Geregelter Ablauf

Geschutzter Bereich (VPN, lokales Netz)

”Standardisiert“

HC, CDA CTF – Capture the Flag

Page 4: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Versuch einer DefinitionIllustration. . .Ablauf

Variationen

HC, CDA CTF – Capture the Flag

Page 5: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Versuch einer DefinitionIllustration. . .Ablauf

Netzlayout

host

?

- �

?

?

-

-

?

-

Game-x ∈ N; 1 ≤ x ≤ 254server

10.2.x.x

10.2.x.x 10.2.x.x

VM

10.2.x.x

10.2.0.3bridge

10.100.0.0/16

VPN Configuration

VPN Gateway10.2.0.0./16

10.1.x.x10.1.0.3bridgeVM

Team 110.1.0.0/16

10.1.x.x 10.1.x.x10.1.x.x

Team 210.2.0.0/16 vulnboxvulnbox

orga10.100.x.x

10.100.x.x

10.100.x.x

orga

orga

10.1.0.0/16

10.100.x.x

host

HC, CDA CTF – Capture the Flag

Page 6: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Versuch einer DefinitionIllustration. . .Ablauf

Flagge holen. . .

HC, CDA CTF – Capture the Flag

Page 7: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Versuch einer DefinitionIllustration. . .Ablauf

. . . und abliefern

HC, CDA CTF – Capture the Flag

Page 8: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

Ursachen

Gedankenlosigkeit

Zeitdruck

Motivationsmangel

Ignoranz

Wissensmangel

Gesunder Menschenverstand → Falsche Annahmen →Mathematiker schreiben die sicherste Software ;-)

HC, CDA CTF – Capture the Flag

Page 9: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

SQL injection

class Email:[. . .]def SendEmail(self, e from, e to, e subj, e hdrs, e body):

c = self.db.cursor()c.execute("select uid from users where email_to=" \

+ e to + " limit 2")res = c.fetchall()if len(res) < 1: raise EmailException("Illegal recipient")if len(res) > 1: die("WTF? Serious sh*t happened; dying")c.execute("insert into emails (e_from, e_to, e_subj, " \ 10

"e_hdrs, e_body) " \"values (%s,%s,%s,%s,%s)" % \(e from, e to, e subj, e hdrs, e body))

self.db.commit()return "250 Yay, email sent!!"

HC, CDA CTF – Capture the Flag

Page 10: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

Buffer overflow

#include <stdio.h>char ADMINUSER[ ] = "root"; char *ADMINPWD = "reindeerflotilla";#define LAUFWERK C 2int format(int drive){puts("formatting hdd");

system("format /dev/laufwerkc");}int main(argc, argv)

int argc;char** argv;

{ char fullname[32]; // no one has a name longer than 32 chars. . .char pass[20]; // who can remember long passwords, anyway? 10

int is admin = 0; int i;puts("What’s your name?\n"); gets(fullname);puts("And what would your password be, Sir?");gets(pass);if (!strcmp(ADMINUSER, fullname) && !strcmp(ADMINPWD, pass))

is admin = 1; if (is admin) format(LAUFWERK C);}

HC, CDA CTF – Capture the Flag

Page 11: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

Dem Compiler gefallt’s schon nicht. . .

HC, CDA CTF – Capture the Flag

Page 12: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

Bis jetzt lauft’s noch. . .

HC, CDA CTF – Capture the Flag

Page 13: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

Buffer overflow

HC, CDA CTF – Capture the Flag

Page 14: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

An alles gedacht? – SUID

Ziel: Vereinsvorstand soll /var/log/auth.log einsehen konnen

Problem: Zugang zu /var/log/auth.log auf Mitglieder vonadm beschrankt

Idee: Vorstand in Gruppe adm packen?

→ zuviele Rechte

Losung: Wir schreiben ein suid-root Binary

Hint: eigentlich reicht ein sgid-adm Binary, aber suid-root istlustiger

HC, CDA CTF – Capture the Flag

Page 15: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

An alles gedacht? – SUID

#include <stdio.h>int main(argc, argv)

int argc;char** argv;

{ char what[8192]; char *acmd;argc−−; argv++;puts("auth.log viewer. . .");setuid(0); setgid(0);if (argc) acmd = *argv; else acmd = "-f";snprintf(what, 8192, "tail %s /var/log/auth.log", acmd); 10

system(what);}

HC, CDA CTF – Capture the Flag

Page 16: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

Besser?

#include <stdio.h>int main(argc, argv)

int argc;char** argv;

{ char what[8192]; char *acmd = "";argc−−; argv++;puts("auth.log viewer. . .");setuid(0); setgid(0);if (argc) if (*argv[0] == ’-’) if (argv[0][1] == ’f’) acmd = "-f";snprintf(what, 8192, "tail %s /var/log/auth.log", acmd); 10

system(what);}

HC, CDA CTF – Capture the Flag

Page 17: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

. . . oder so vielleicht?

#include <stdio.h>#include <unistd.h>static const char AUTHFILE[ ] = "/var/log/auth.log";int main(argc, argv)

int argc;char** argv;

{ char what[8192]; char *acmd = "";argc−−; argv++;puts("auth.log viewer. . .");setuid(0); setgid(0); 10

if (argc) if (*argv[0] == ’-’) if (argv[0][1] == ’f’) acmd = "-f";execl("/usr/bin/tail", "/usr/bin/tail",

*acmd ? acmd : AUTHFILE,*acmd ? AUTHFILE : NULL, NULL);

system(what);}

HC, CDA CTF – Capture the Flag

Page 18: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

UrsachenSQL injectionBuffer overflowSUID

SUID ist gefahrlich

system() sucht tail in $PATH

Ausfuhrender Benutzer hat volle Kontrolle uber Environment

execl() bekommt absoulten Pfad → sicher

Was macht tail? Gibt es eine Version von tail, die auf dasEnvironment zugreift? → wissen wir nicht

Losung: Environment loschen und manuell setzenAber: Gibt es andere Elemente, die zu einem suid-rootProgramm durchgereicht werden? →Ja. Je nachUNIX-Vendor unterschiedlich! Beispiele:

File descriptors (fds)Arguments (args)Current working directory (cwd)Resource limits (rlimits)POSIX-Signals (signals)

Quelle: http://cr.yp.to/qmail/guarantee.html

HC, CDA CTF – Capture the Flag

Page 19: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Relevanz in der heutigen ZeitPunktesystemAdvisories

Heute noch relevant?

Eigentlich musste es doch heute jeder besser wissen. . .

”BUGS: . . . still crashes randomly; probably has some memory

leaks“ – man Xnest

→ Ausbruch aus XEN DOMu moglich

”It is possible for a corrupted file system to cause a crash.“ –

FreeBSD Manual 12.Juli 2006

→ Niemals fremde USB-Sticks mounten

”. . . under certain circumstances, jabberd leaks memory. This

bug is very hard to fix. In the meantime use a garbagecollector.“ April 2008

HC, CDA CTF – Capture the Flag

Page 20: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Relevanz in der heutigen ZeitPunktesystemAdvisories

Offensive und defensive Punkte

Pro Flagge ein Punkt

Jede Flagge pro Team nur einmal gultig

Allgemeine Gultigkeitsdauer; Standard: 15min

AP:”Flaggen zahlen nur als offensiv, wenn das angreifende

Team den Ursprungsservice selbst am Laufen hat“

Ist das sinnvoll?Ausbildung von Blackhats?

Jede innerhalb der Gultigkeitsdauer von keinem Teamgemeldete Flagge → Ein Defensivpunkt

HC, CDA CTF – Capture the Flag

Page 21: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Relevanz in der heutigen ZeitPunktesystemAdvisories

Defensive & Advisories

Advisories konnen unabhangig von Flaggenabgabe und-verteidigung geschrieben werden

Jedes Advisory je nach Wichtigkeit n Punkte; n ∈ N; n > 0

Sollten Advisories sofort veroffentlicht werden?

JaNein

HC, CDA CTF – Capture the Flag

Page 22: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Relevanz in der heutigen ZeitPunktesystemAdvisories

Beispieladvisory

HC, CDA CTF – Capture the Flag

Page 23: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Warum ein eigener CTF?

Dienste coden macht Spaß

→ Protokolle und Betriebssystem kennenlernen

Perspektivenwechsel

Lustig auf Konferenzen; große CTFs meist uber VPN

HC, CDA CTF – Capture the Flag

Page 24: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Dienste schreiben

Mischung aus komplexen und einfachen Diensten

Verschiedene Programmiersprachen

”C“

Scriptsprache (z.B. python, ruby, unrealscript)Binary-only Dienst

DoS-Attacken moglichst unmoglich machen → werden sonstausgenutzt – jeglicher Verbote zum Trotz

”Wohldefinierte“ Sicherheitslucken → Auswirkungen sollten

bei Entwurf bekannt sein

HC, CDA CTF – Capture the Flag

Page 25: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Gameserver

Flaggen an Dienste verteilen

Flaggen von Diensten einsammeln

→ Flag IDs vergeben

”Gestohlene“ Flaggen entgegennehmen

Verwaltung von Advisories

HC, CDA CTF – Capture the Flag

Page 26: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Testscripts

Schnittstelle zwischen Gameserver und Dienst

Meistens vom Dienstautor selbst geschrieben

Funktionen:

store IP FLAGID FLAGretrieve IP FLAGID FLAGtest IP

Ruckgabewert entscheidend

HC, CDA CTF – Capture the Flag

Page 27: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Beispieltestscript – store

#!/usr/local/bin/python[what, ip, flagid, flag] = sys.argv[1:]if what == ’store’:

s = socket.socket(socket.AF INET, socket.SOCK STREAM)s.connect(tuple([ip, 2525]))s.send("helo score.bot\n")s.send("mail from: dood <[email protected]>\n")s.send("rcpt to: " + str(time()) + " <%[email protected]>\n" % flagid)s.send("data\nSubject: hello world\n\n%s\n.\nquit\n" % flag)f = s.makefile("r") 10

res = f.read()for i in res.split("\n"):

if (len(i) > 3) and (i[0:3] == "221"):print "Flag stored!"

sys.exit(0)sys.exit(1)

HC, CDA CTF – Capture the Flag

Page 28: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Beispieltestscript – retrieve

#!/usr/local/bin/python[ip, what, flagid, flag] = sys.argv[1:]elif what == ’retrieve’:

s = socket.socket(socket.AF INET, socket.SOCK STREAM)try:

s.connect(tuple([ip, 1111]))s.sendall("auth user: me pwd: foobar\nget %s\nquit\n" % flagid)

except: sys.exit(2) # connection failedf = s.makefile("r")res = f.read() 10

for i in res.split("\n"):if (len(i) > 3) and (i == flag):

print "Flag retrieved!"

sys.exit(0) # all OKsys.exit(1) # service broken

HC, CDA CTF – Capture the Flag

Page 29: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Beispieltestscript

#!/usr/local/bin/pythonfrom sys import exit, argvdef store((ip, flagid, flag)): passdef retrieve((ip, flagid, flag)): passdef test((ip)): passtry:

{ ’store’: store,’retrieve’: retrieve,’test’: test

}[argv[1]](tuple(argv[2:])) 10

except Exception, e:print "Error: " + str(e)print "Usage: %s store|retrieve IP FLAGID FLAG" % argv[0]print " %s test IP" % argv[0]

HC, CDA CTF – Capture the Flag

Page 30: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Probleme

Teams schlecht vorbereitet

Keine Kenntnisse uber CTF-Ablauf

Netzwerk/Hardware lauft nicht wie geplant → fur Redundanzsorgen

Lokalitaten nicht verfugbar

Platzregen

Strom- und/oder Netzwerkausfalle

Versehentliches Steckerziehen

HC, CDA CTF – Capture the Flag

Page 31: Einf¨uhrung – Wtf ist ein CTF? Klassische …Einf¨uhrung – Wtf ist ein CTF? Klassische Sicherheitsl¨ucken Diskussion Ein eigener CTF CTF – Capture the Flag Hans-Christian

Einfuhrung – Wtf ist ein CTF?Klassische Sicherheitslucken

DiskussionEin eigener CTF

Warum ein eigener CTF?Dienste schreibenGameserverProbleme

Upcoming CTFs

CIPHER 4 http://www.cipher-ctf.org/

DA-OPEN http://ctf.sec-tud.de/

→ MRMCDs111b 6. September 2008 in Darmstadt

HC, CDA CTF – Capture the Flag