java chat vor DDOs schützen

alex8686

Mitglied
hallo, kann mir einer helfen? Mein Chat wird dauernd von irgendwelche Scriptkiddies lahmgelegt ...bekomme zuviele Verbindungen auf dem Server von 1 und diesselbe IP.

Gibt es ein Script oder eine Anwendung um den mist zu stoppen? zb bei zuvielen zugriffen von einer IP direkt die IP in der blacklist legen und den zugriff auf dem Server zu verbieten?

Chat läuft momentan auf einer Windows Umgebung. ( ist ein Java Chat mit Sockets / Threads )

Danke im vorraus,hab nämlich kein bock den Server 3 x am tag zu reseten.:rtfm:
 

Noctarius

Top Contributor
Du speicherst einfach die Connections in den letzten 5 Minuten. Taucht eine zu oft auf, gibt's halt eine Art Timeban. Normal sollte man sowas aber schon in einer Firewall davor abhandeln.
 

Noctarius

Top Contributor
Firewalls helfen nur dann weiter, wenn man weiß wie man damit umgehen muss. Nur Firewall installieren und alle Ports bis auf einen sperren bringt dir auch nichts.
 
N

nillehammer

Gast
Das, was Du beschreibst ist wohl ein SYN-Flood Angriff (ein Client schickt ganz viele SYNs an einen TCP-Port, was zu vielen halb offenen Verbindungen führt, die die Systemresourcen blockieren). Erkennen kann man das mit Hilfe des netstat-Befehls. Dagegen helfen sog. SYN-Cookies. Das muss man bei der Firewall/Netzwerkeinstellung konfigurieren. Bei iptables/Linux wüsste ich wie's geht. Bei Windows musst Du selber suchen.
 
Zuletzt bearbeitet von einem Moderator:

ice-breaker

Top Contributor
Doch. Wenn du 5 Sekunden dein Gehirn anstrengst und mehr als Copy&Paste kannst, hast du das Problem auch innerhalb der nächsten 30 Minuten (sehr großzügig!) behoben.

Es scheint aber sowohl an Bedingung 1 & 2 zu scheitern :noe:
 

alex8686

Mitglied
ich versteh schon worauf du hinaus willst, hier ist der code vom ChatServer

Java:
    public ChatServer()
    {
        master = this;
        hks = new Hashtable();
        reglock = new Hashtable();
        gblock = new Hashtable();
        checkpwd = new Hashtable();
        maillock = new Hashtable();
        naplock = new Hashtable();
        startTime = "";
        license = "";
        rnd = new Random();
        ready = false;
        users = new Hashtable();
        config = null;
        pstring = new pString(this);
        time = null;
        registry = null;
        adminPasswd = "";
        tout = null;
        pout = null;
        ipout = null;
        gout = null;
        Lizensiert = false;
        speed = 1;
        ObjectCount = new int[3];
        ltxt = "";
        byte abyte0[] = new byte[80];
        String s = "";
        try
        {
            Thread thread = new Thread();
            Thread.sleep(1000L);
        }
        catch(Exception exception) { }
        speed = 60;
        System.out.println();
        try
        {
            Thread thread1 = new Thread();
            Thread.sleep(1000L);
        }
        catch(Exception exception1) { }
        try
        {
            File file = new File("firststart");
            if(file.isFile())
            {
                System.out.println("Erster Start des System wird vorbereitet...");
                file.delete();
            }
        }
        catch(Exception exception2) { }
        String s1 = "";
        try
        {
            InetAddress inetaddress = InetAddress.getLocalHost();
            s1 = inetaddress.getHostAddress();
        }
        catch(Exception exception4)
        {
            s1 = "127.0.0.1";
        }
        System.out.println("Starte ChatServer  an " + s1);
        String s2 = "";
        config = new Config(this, "config/chat.ini");
        String s3 = (String)config.hash.get("HOST");
        System.setErr(tout);
        Input.bot = master.readFile("config/bot.ini");
        String s4 = null;
        String s5 = null;
        char c = '\u07CF';
        registry = new Registry(this);
        registry.start();
        time = new Time(this);
        time.setPriority(4);
        time.start();
        s4 = (String)config.hash.get("iport");
        s5 = (String)config.hash.get("oport");
        int i = 0;
        int j = 0;
        try
        {
            i = Integer.parseInt(s4);
        }
        catch(Exception exception5)
        {
            i = 1972;
        }
        try
        {
            j = Integer.parseInt(s5);
        }
        catch(Exception exception6)
        {
            j = 1973;
        }
        AcceptInput acceptinput = new AcceptInput(this, j);
        acceptinput.start();
        acceptinput.setPriority(8);
        AcceptOutput acceptoutput = new AcceptOutput(this, i);
        acceptoutput.start();
        acceptoutput.setPriority(8);
        startTime = (new Date()).toLocaleString();
        String s6 = master.pstring.replace(startTime, " ", "_");
        try
        {
        	FileOutputStream fileoutputstream3 = new FileOutputStream("files/galerie.htm");
            gout = new PrintStream(fileoutputstream3);
        	FileOutputStream fileoutputstream2 = new FileOutputStream("logs/iplog.txt");
            ipout = new PrintStream(fileoutputstream2);
            FileOutputStream fileoutputstream1 = new FileOutputStream("files/out.htm");
            pout = new PrintStream(fileoutputstream1);
            if(config.preview())
                pout.println("<html>\n<body>\n");
                pout.println("<font face=\"Verdana\" size=\"1\">");
                pout.println(String.valueOf((String)master.config.hash.get("scrolling0")));
                pout.println(String.valueOf((String)master.config.hash.get("watch")));
        }
        catch(Exception exception7) { }
    }


mhm, seh da aber keinen großen fehler.. :autsch:
 
Zuletzt bearbeitet von einem Moderator:

alex8686

Mitglied
Java:
public synchronized void run()
    {
        do
        {
            int i = 0;
            try
            {
                try
                {
                    ss = new ServerSocket(port);
                    ss.setSoTimeout(5000);
                }
                catch(Exception exception)
                {
                    System.out.println("Der Port " + Integer.toString(port) + " ist nicht verfuegbar");
                    System.exit(1);
                }
                do
                    try
                    {
                        do
                        {
                            while((sock = ss.accept()) == null) ;
                            tinput[i] = new Input(master, sock);
                            tinput[i].start();
                        } while(++i <= 99);
                        i = 0;
                    }
                    catch(SocketException socketexception) { }
                    catch(InterruptedIOException interruptedioexception) { }
                    catch(Exception exception2)
                    {
                        master.out("AcceptInputError method run:" + exception2.toString());
                    }
                while(true);
            }
            catch(Exception exception1)
            {
                master.out("AcceptInputError method run:(FATAL ERROR RESTARTING SOCKET)" + exception1.toString());
            }
        } while(true);
    }
 
Zuletzt bearbeitet von einem Moderator:

alex8686

Mitglied
Java:
import java.io.InterruptedIOException;
import java.net.*;

public class AcceptOutput extends Thread
{

    public AcceptOutput(ChatServer chatserver, int i)
    {
        port = 0;
        ss = null;
        sock = null;
        output = null;
        master = null;
        port = 1973;
        ss = null;
        sock = null;
        output = new Output[1000];
        master = null;
        port = i;
        master = chatserver;
    }

    public synchronized void run()
    {
        int i = 0;
        do
            try
            {
                try
                {
                    ss = new ServerSocket(port,100);
                    ss.setSoTimeout(5000);
                }
                catch(Exception exception)
                {
                    master.out("Der Port " + Integer.toString(port) + " ist nicht verfuegbar");
                    System.exit(1);
                }
                do
                {
                    if(++i > 999)
                        i = 0;
                    try
                    {
                        if((sock = ss.accept()) != null)
                        {
                            output[i] = new Output(master, sock);
                            output[i].start();
                            System.out.println("Einkommende Verbindung: " + sock.getInetAddress().getHostAddress());
                            System.out.println("IP Host / Port: " + sock.getRemoteSocketAddress());
                        }
                    }
                    catch(SocketException socketexception) { }
                    catch(InterruptedIOException interruptedioexception)
                    {
                        output[i] = null;
                        i--;
                    }
                    catch(Exception exception2)
                    {
                        master.out("AcceptOutputError line 38:" + exception2.toString());
                    }
                } while(true);
            }
            catch(Exception exception1)
            {
                master.out("AcceptOutputError line 42:(FATAL ERROR RESTARTING SOCKET:" + exception1.toString());
            }
        while(true);
    }

    static String classVersion = "1";
    int port;
    ServerSocket ss;
    Socket sock;
    Output output[];
    ChatServer master;

}
 

alex8686

Mitglied
Java:
    public ChatServer()
    {
        master = this;
        hks = new Hashtable();
        reglock = new Hashtable();
        gblock = new Hashtable();
        checkpwd = new Hashtable();
        maillock = new Hashtable();
        naplock = new Hashtable();
        startTime = "";
        license = "";
        rnd = new Random();
        ready = false;
        users = new Hashtable();
        config = null;
        pstring = new pString(this);
        time = null;
        registry = null;
        adminPasswd = "";
        tout = null;
        pout = null;
        ipout = null;
        gout = null;
        Lizensiert = false;
        speed = 1;
        ObjectCount = new int[3];
        ltxt = "";
        byte abyte0[] = new byte[80];
        String s = "";
        try
        {
            Thread thread = new Thread();
            Thread.sleep(1000L);
        }
        catch(Exception exception) { }
        speed = 60;
        System.out.println();
        try
        {
            Thread thread1 = new Thread();
            Thread.sleep(1000L);
        }
        catch(Exception exception1) { }
        try
        {
            File file = new File("firststart");
            if(file.isFile())
            {
                System.out.println("Erster Start des System wird vorbereitet...");
                file.delete();
            }
        }
        catch(Exception exception2) { }
        String s1 = "";
        try
        {
            InetAddress inetaddress = InetAddress.getLocalHost();
            s1 = inetaddress.getHostAddress();
        }
        catch(Exception exception4)
        {
            s1 = "127.0.0.1";
        }
        System.out.println("Starte ChatServer  an " + s1);
        String s2 = "";
        config = new Config(this, "config/chat.ini");
        String s3 = (String)config.hash.get("HOST");
        System.setErr(tout);
        Input.bot = master.readFile("config/bot.ini");
        String s4 = null;
        String s5 = null;
        char c = '\u07CF';
        registry = new Registry(this);
        registry.start();
        time = new Time(this);
        time.setPriority(4);
        time.start();
        s4 = (String)config.hash.get("iport");
        s5 = (String)config.hash.get("oport");
        int i = 0;
        int j = 0;
        try
        {
            i = Integer.parseInt(s4);
        }
        catch(Exception exception5)
        {
            i = 1972;
        }
        try
        {
            j = Integer.parseInt(s5);
        }
        catch(Exception exception6)
        {
            j = 1973;
        }
        AcceptInput acceptinput = new AcceptInput(this, j);
        acceptinput.start();
        acceptinput.setPriority(8);
        AcceptOutput acceptoutput = new AcceptOutput(this, i);
        acceptoutput.start();
        acceptoutput.setPriority(8);
        startTime = (new Date()).toLocaleString();
        String s6 = master.pstring.replace(startTime, " ", "_");
        try
        {
        	FileOutputStream fileoutputstream3 = new FileOutputStream("files/galerie.htm");
            gout = new PrintStream(fileoutputstream3);
        	FileOutputStream fileoutputstream2 = new FileOutputStream("logs/iplog.txt");
            ipout = new PrintStream(fileoutputstream2);
            FileOutputStream fileoutputstream1 = new FileOutputStream("files/out.htm");
            pout = new PrintStream(fileoutputstream1);
            if(config.preview())
                pout.println("<html>\n<body>\n");
                pout.println("<font face=\"Verdana\" size=\"1\">");
                pout.println(String.valueOf((String)master.config.hash.get("scrolling0")));
                pout.println(String.valueOf((String)master.config.hash.get("watch")));
        }
        catch(Exception exception7) { }
    }
 

Noctarius

Top Contributor
Also in diesem Quellcodegesülze wundert es mich nicht, dass du keine Fehler findest. Schon mal an Leerzeilen gedacht zur Abtrennung von verschiedenen Gedankengängen? Oder bist du auch ein Verfechter der Theorie "Leerzeilen machen den Quellcode langsam"? :D

PS: Das man mit so einem niedlichen kleinen Chatserver online gehen kann, ich programmier echt zuviel Kram drum herum :p
 

alex8686

Mitglied
Also in diesem Quellcodegesülze wundert es mich nicht, dass du keine Fehler findest. Schon mal an Leerzeilen gedacht zur Abtrennung von verschiedenen Gedankengängen? Oder bist du auch ein Verfechter der Theorie "Leerzeilen machen den Quellcode langsam"? :D

PS: Das man mit so einem niedlichen kleinen Chatserver online gehen kann, ich programmier echt zuviel Kram drum herum :p

und was meinst du mit niedlichen kleinen ChatServer? wie könnte ich ihn deiner meinung nach erweitern bzw stabilisieren?!

mfg alex
 

Noctarius

Top Contributor
Och ich habe einen HTML-Streaming Chatserver (welcher also direkt in HTML "streamed" und kein Applet benötigt) und der hat viel viel viel mehr Klassen und noch viel mehr Code :p

Aber ich glaube der soll auch ein anderes Klientel erfreuen ;)
 
S

SlaterB

Gast
System.out.println("Einkommende Verbindung: " + sock.getInetAddress().getHostAddress());
System.out.println("IP Host / Port: " + sock.getRemoteSocketAddress());

funktioniert das? wie sieht das Log im Problemfall aus?
hiermit kennst du also eine bestimmte IP oder erkennst im Programmverlauf dynamisch eine häufige IP,
jetzt muss du nur noch dazu was programmieren,
mehr ist gar nicht zu sagen und auch das ist eigentlich schon klar,

oder keine weiteren Ideen dazu? IPs sammeln mit Anzahl, evtl. beschränkt auf Zeit, Verbindung ablehnen wenn böse IP usw?
wobei auf dieser Ebene der Schaden schon angerichtet sein kann,
du schützt vielleicht noch die Anzahl der Threads in deinem Programm und i vor schnellen Maximum, aber Verbindungen werden initial wohl trotzdem aufgebaut,
da mögen die anderen Ideen Richtung Firewall usw. besser sein als nur Java
 

Noctarius

Top Contributor
Wie ich bereits sagte, eine gut konfigurierte Firewall mit IPS :)

Ansonsten bleibt ihm nichts anderes als Zählen und blocken UND auf nio wechseln :) Ich glaube eher der Threadcount dürfte sein Problem werden.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Chat Programm in Java Java Basics - Anfänger-Themen 1
R Problem mit Java-Chat Java Basics - Anfänger-Themen 2
V Java Chat Programm Problem mit IP Addresse Java Basics - Anfänger-Themen 7
xDarkSunx Java Chat Hilfe Java Basics - Anfänger-Themen 9
C Java Chat Tutorials Java Basics - Anfänger-Themen 1
I Liste in Java (Chat-Frage) Java Basics - Anfänger-Themen 3
A Möchte Java - Chat in meine Homepage einbinden. Java Basics - Anfänger-Themen 4
J Java-Chat geht nicht | Brauche dringent hilfe! Java Basics - Anfänger-Themen 3
S Java-Chat und Smilies Java Basics - Anfänger-Themen 8
A Java Chat Bauen !?!? Java Basics - Anfänger-Themen 10
lomtas Chat in Java Java Basics - Anfänger-Themen 3
J Problem mit java-basiertem Chat Java Basics - Anfänger-Themen 4
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben