亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sniffer.c

?? sniffex源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * sniffex.c * * Sniffer example of TCP/IP packet capture using libpcap. *  * Version 0.1.1 (2005-07-05) * Copyright (c) 2005 The Tcpdump Group * * This software is intended to be used as a practical example and  * demonstration of the libpcap library; available at: * http://www.tcpdump.org/ * **************************************************************************** * * This software is a modification of Tim Carstens' "sniffer.c" * demonstration source code, released as follows: *  * sniffer.c * Copyright (c) 2002 Tim Carstens * 2002-01-07 * Demonstration of using libpcap * timcarst -at- yahoo -dot- com *  * "sniffer.c" is distributed under these terms: *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 4. The name "Tim Carstens" may not be used to endorse or promote *    products derived from this software without prior written permission * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * <end of "sniffer.c" terms> * * This software, "sniffex.c", is a derivative work of "sniffer.c" and is * covered by the following terms: * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Because this is a derivative work, you must comply with the "sniffer.c" *    terms reproduced above. * 2. Redistributions of source code must retain the Tcpdump Group copyright *    notice at the top of this source file, this list of conditions and the *    following disclaimer. * 3. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 4. The names "tcpdump" or "libpcap" may not be used to endorse or promote *    products derived from this software without prior written permission. * * THERE IS ABSOLUTELY NO WARRANTY FOR THIS PROGRAM. * BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY * FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN * OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES * PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED * OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS * TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE * PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, * REPAIR OR CORRECTION. *  * IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING * WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR * REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, * INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING * OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED * TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY * YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER * PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE * POSSIBILITY OF SUCH DAMAGES. * <end of "sniffex.c" terms> *  **************************************************************************** * * Below is an excerpt from an email from Guy Harris on the tcpdump-workers * mail list when someone asked, "How do I get the length of the TCP * payload?" Guy Harris' slightly snipped response (edited by him to * speak of the IPv4 header length and TCP data offset without referring * to bitfield structure members) is reproduced below: *  * The Ethernet size is always 14 bytes. *  * <snip>...</snip> * * In fact, you *MUST* assume the Ethernet header is 14 bytes, *and*, if  * you're using structures, you must use structures where the members  * always have the same size on all platforms, because the sizes of the  * fields in Ethernet - and IP, and TCP, and... - headers are defined by  * the protocol specification, not by the way a particular platform's C  * compiler works.) * * The IP header size, in bytes, is the value of the IP header length, * as extracted from the "ip_vhl" field of "struct sniff_ip" with * the "IP_HL()" macro, times 4 ("times 4" because it's in units of * 4-byte words).  If that value is less than 20 - i.e., if the value * extracted with "IP_HL()" is less than 5 - you have a malformed * IP datagram. * * The TCP header size, in bytes, is the value of the TCP data offset, * as extracted from the "th_offx2" field of "struct sniff_tcp" with * the "TH_OFF()" macro, times 4 (for the same reason - 4-byte words). * If that value is less than 20 - i.e., if the value extracted with * "TH_OFF()" is less than 5 - you have a malformed TCP segment. * * So, to find the IP header in an Ethernet packet, look 14 bytes after  * the beginning of the packet data.  To find the TCP header, look  * "IP_HL(ip)*4" bytes after the beginning of the IP header.  To find the * TCP payload, look "TH_OFF(tcp)*4" bytes after the beginning of the TCP * header. *  * To find out how much payload there is: * * Take the IP *total* length field - "ip_len" in "struct sniff_ip"  * - and, first, check whether it's less than "IP_HL(ip)*4" (after * you've checked whether "IP_HL(ip)" is >= 5).  If it is, you have * a malformed IP datagram. * * Otherwise, subtract "IP_HL(ip)*4" from it; that gives you the length * of the TCP segment, including the TCP header.  If that's less than * "TH_OFF(tcp)*4" (after you've checked whether "TH_OFF(tcp)" is >= 5), * you have a malformed TCP segment. * * Otherwise, subtract "TH_OFF(tcp)*4" from it; that gives you the * length of the TCP payload. * * Note that you also need to make sure that you don't go past the end  * of the captured data in the packet - you might, for example, have a  * 15-byte Ethernet packet that claims to contain an IP datagram, but if  * it's 15 bytes, it has only one byte of Ethernet payload, which is too  * small for an IP header.  The length of the captured data is given in  * the "caplen" field in the "struct pcap_pkthdr"; it might be less than  * the length of the packet, if you're capturing with a snapshot length  * other than a value >= the maximum packet size. * <end of response> *  **************************************************************************** *  * Example compiler command-line for GCC: *   gcc -Wall -o sniffex sniffex.c -lpcap *  **************************************************************************** * * Code Comments * * This section contains additional information and explanations regarding * comments in the source code. It serves as documentaion and rationale * for why the code is written as it is without hindering readability, as it * might if it were placed along with the actual code inline. References in * the code appear as footnote notation (e.g. [1]). * * 1. Ethernet headers are always exactly 14 bytes, so we define this * explicitly with "#define". Since some compilers might pad structures to a * multiple of 4 bytes - some versions of GCC for ARM may do this - * "sizeof (struct sniff_ethernet)" isn't used. *  * 2. Check the link-layer type of the device that's being opened to make * sure it's Ethernet, since that's all we handle in this example. Other * link-layer types may have different length headers (see [1]). * * 3. This is the filter expression that tells libpcap which packets we're * interested in (i.e. which packets to capture). Since this source example * focuses on IP and TCP, we use the expression "ip", so we know we'll only * encounter IP packets. The capture filter syntax, along with some * examples, is documented in the tcpdump man page under "expression." * Below are a few simple examples: * * Expression			Description * ----------			----------- * ip					Capture all IP packets. * tcp					Capture only TCP packets. * tcp port 80			Capture only TCP packets with a port equal to 80. * ip host 10.1.2.3		Capture all IP packets to or from host 10.1.2.3. * **************************************************************************** * */#define APP_NAME		"sniffex"#define APP_DESC		"Sniffer example using libpcap"#define APP_COPYRIGHT	"Copyright (c) 2005 The Tcpdump Group"#define APP_DISCLAIMER	"THERE IS ABSOLUTELY NO WARRANTY FOR THIS PROGRAM."#include <pcap.h>#include <stdio.h>#include <string.h>#include <stdlib.h>#include <ctype.h>#include <errno.h>#include <sys/types.h>#include <sys/socket.h>#include <netinet/in.h>#include <arpa/inet.h>/* default snap length (maximum bytes per packet to capture) */#define SNAP_LEN 1518/* ethernet headers are always exactly 14 bytes [1] */#define SIZE_ETHERNET 14/* Ethernet addresses are 6 bytes */#define ETHER_ADDR_LEN	6/* Ethernet header */struct sniff_ethernet {        u_char  ether_dhost[ETHER_ADDR_LEN];    /* destination host address */        u_char  ether_shost[ETHER_ADDR_LEN];    /* source host address */        u_short ether_type;                     /* IP? ARP? RARP? etc */};/* IP header */struct sniff_ip {        u_char  ip_vhl;                 /* version << 4 | header length >> 2 */        u_char  ip_tos;                 /* type of service */        u_short ip_len;                 /* total length */        u_short ip_id;                  /* identification */        u_short ip_off;                 /* fragment offset field */        #define IP_RF 0x8000            /* reserved fragment flag */        #define IP_DF 0x4000            /* dont fragment flag */        #define IP_MF 0x2000            /* more fragments flag */        #define IP_OFFMASK 0x1fff       /* mask for fragmenting bits */        u_char  ip_ttl;                 /* time to live */        u_char  ip_p;                   /* protocol */        u_short ip_sum;                 /* checksum */        struct  in_addr ip_src,ip_dst;  /* source and dest address */};#define IP_HL(ip)               (((ip)->ip_vhl) & 0x0f)#define IP_V(ip)                (((ip)->ip_vhl) >> 4)/* TCP header */typedef u_int tcp_seq;struct sniff_tcp {        u_short th_sport;               /* source port */        u_short th_dport;               /* destination port */        tcp_seq th_seq;                 /* sequence number */        tcp_seq th_ack;                 /* acknowledgement number */        u_char  th_offx2;               /* data offset, rsvd */#define TH_OFF(th)      (((th)->th_offx2 & 0xf0) >> 4)        u_char  th_flags;        #define TH_FIN  0x01        #define TH_SYN  0x02        #define TH_RST  0x04        #define TH_PUSH 0x08        #define TH_ACK  0x10        #define TH_URG  0x20        #define TH_ECE  0x40        #define TH_CWR  0x80        #define TH_FLAGS        (TH_FIN|TH_SYN|TH_RST|TH_ACK|TH_URG|TH_ECE|TH_CWR)        u_short th_win;                 /* window */        u_short th_sum;                 /* checksum */        u_short th_urp;                 /* urgent pointer */};voidgot_packet(u_char *args, const struct pcap_pkthdr *header, const u_char *packet);voidprint_payload(const u_char *payload, int len);voidprint_hex_ascii_line(const u_char *payload, int len, int offset);voidprint_app_banner(void);voidprint_app_usage(void);/* * app name/banner */voidprint_app_banner(void){	printf("%s - %s\n", APP_NAME, APP_DESC);	printf("%s\n", APP_COPYRIGHT);	printf("%s\n", APP_DISCLAIMER);	printf("\n");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一级二级| 色诱亚洲精品久久久久久| 亚洲一区在线播放| 亚洲女厕所小便bbb| 亚洲视频图片小说| 亚洲丝袜美腿综合| 一区二区三区精品视频在线| 亚洲免费观看高清完整版在线观看| 亚洲国产精品传媒在线观看| 中文字幕在线播放不卡一区| ...中文天堂在线一区| 亚洲美女偷拍久久| 亚洲成人黄色小说| 精东粉嫩av免费一区二区三区| 黄色日韩网站视频| 99vv1com这只有精品| 欧美三级三级三级| 日韩欧美国产一区在线观看| www成人在线观看| 国产欧美日本一区视频| 亚洲精品国产视频| 久久99热99| av在线这里只有精品| 欧美日韩精品欧美日韩精品| 精品少妇一区二区三区 | 高清不卡一二三区| 色狠狠一区二区| 精品久久久久久久人人人人传媒 | 国产精品一区二区久久精品爱涩| 波多野结衣中文字幕一区二区三区| 色一区在线观看| 91麻豆精品国产91久久久久久久久 | 国产精品一区在线| 91久久人澡人人添人人爽欧美| 欧美一区二区三区白人| 国产精品色噜噜| 免费观看在线综合色| 色综合久久中文综合久久牛| 日韩色在线观看| 亚洲免费观看高清完整版在线 | 欧美精品在线视频| 国产精品久久久久aaaa| 男女男精品视频| 日本一区二区综合亚洲| 日韩av午夜在线观看| 国产成人精品一区二区三区四区| 欧美日韩一级视频| 亚洲欧洲www| 国产麻豆精品95视频| 欧美久久久久久蜜桃| 亚洲女子a中天字幕| 国产精品一区二区视频| 91麻豆精品国产自产在线观看一区| 国产精品三级电影| 国产美女久久久久| 亚洲精品在线网站| 日本欧美肥老太交大片| 欧美在线播放高清精品| 国产精品久久免费看| 国产一区二区三区四区五区美女 | 另类中文字幕网| 欧美卡1卡2卡| 亚洲一区二区在线免费观看视频| 成人黄色网址在线观看| 精品日韩一区二区三区| 免费成人性网站| 日韩免费观看高清完整版| 日日夜夜精品视频免费| 欧美三级三级三级爽爽爽| 亚洲最新在线观看| 欧美怡红院视频| 亚洲一区在线看| 91黄视频在线观看| 一二三区精品福利视频| 91老师片黄在线观看| 亚洲精品成a人| 欧美色综合久久| 亚洲成人激情综合网| 欧美伦理电影网| 奇米精品一区二区三区在线观看| 欧美一区二区三区在线视频| 日韩成人一级大片| 欧美精品一区二区三区久久久| 久久精品国产澳门| 久久精品男人天堂av| eeuss鲁片一区二区三区| 日韩理论在线观看| 欧美三级一区二区| 激情小说亚洲一区| 国产精品卡一卡二| 精品污污网站免费看| 男男成人高潮片免费网站| 久久久777精品电影网影网| 成人丝袜18视频在线观看| 亚洲欧美在线另类| 国产不卡一区视频| 久久综合九色综合欧美亚洲| 亚洲欧洲av色图| 在线视频亚洲一区| 日本强好片久久久久久aaa| 日韩欧美国产高清| 成人高清免费在线播放| 首页综合国产亚洲丝袜| 图片区小说区区亚洲影院| 日韩小视频在线观看专区| 欧美日韩国产综合久久| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 精品国产一二三区| 国产综合久久久久久久久久久久| 国产欧美综合在线| 欧美特级限制片免费在线观看| 美女视频免费一区| 国产精品不卡一区| 欧美一区在线视频| 色综合婷婷久久| 老汉av免费一区二区三区| 中文字幕在线不卡国产视频| 3d成人h动漫网站入口| 成人免费看片app下载| 日一区二区三区| 中文字幕一区二区三区色视频| 这里只有精品电影| 91在线视频观看| 九九九精品视频| 一区二区三区精品在线观看| 国产偷v国产偷v亚洲高清| 7777精品伊人久久久大香线蕉完整版 | 国产精品福利影院| 日韩美女视频一区二区在线观看| 99久久99久久精品免费看蜜桃| 轻轻草成人在线| 一区二区三区久久久| 中文字幕免费观看一区| 欧美一级理论性理论a| 色综合久久88色综合天天6| 国产剧情一区二区| 久久精品国产亚洲5555| 天天做天天摸天天爽国产一区| 中文字幕在线观看不卡| 国产日韩欧美综合在线| 欧美不卡一二三| 日韩视频在线一区二区| 欧美日韩午夜影院| 欧洲生活片亚洲生活在线观看| 99精品国产视频| 成人黄色片在线观看| 国产福利不卡视频| 国产激情视频一区二区在线观看 | 欧美亚洲另类激情小说| 99精品久久只有精品| 丰满少妇久久久久久久| 国产精品 欧美精品| 国产黄色91视频| 国产成人av电影免费在线观看| 开心九九激情九九欧美日韩精美视频电影 | 欧美精品一区二区三区蜜桃| 欧美一区二区三区免费大片| 欧美日韩国产a| 6080日韩午夜伦伦午夜伦| 欧美日高清视频| 555www色欧美视频| 日韩欧美视频在线| 亚洲一区自拍偷拍| 五月激情六月综合| 日本中文在线一区| 激情五月婷婷综合| av在线这里只有精品| 在线精品视频一区二区三四| 在线视频欧美精品| 欧美一三区三区四区免费在线看| 日韩欧美精品三级| 日本一区二区不卡视频| 亚洲久草在线视频| 秋霞午夜av一区二区三区| 激情图区综合网| aaa亚洲精品一二三区| 欧美亚日韩国产aⅴ精品中极品| 欧美日韩黄视频| 26uuu成人网一区二区三区| 中文字幕乱码亚洲精品一区| 亚洲三级在线观看| 三级在线观看一区二区| 国产一区二区精品在线观看| 99久久综合99久久综合网站| 欧美三级电影在线看| 日韩免费一区二区| 一色屋精品亚洲香蕉网站| 亚洲国产视频在线| 韩国中文字幕2020精品| 99精品久久久久久| 日韩精品一区在线| 亚洲视频资源在线| 日日夜夜免费精品| aaa国产一区| 精品精品欲导航| 亚洲一二三区视频在线观看| 国产精品亚洲第一| 在线播放国产精品二区一二区四区| 国产视频一区二区在线| 亚洲成人777|