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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? sniffex.c

?? 《linux編程技術(shù)詳解》 linux編程入門的好書
?? 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");

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
8v天堂国产在线一区二区| 日韩一区欧美小说| 日韩精品一二三区| 在线观看91av| 蜜桃视频第一区免费观看| 日韩视频一区在线观看| 老司机午夜精品| 久久综合久久综合九色| 国产凹凸在线观看一区二区| 欧美高清在线精品一区| 99视频热这里只有精品免费| 欧美日韩中字一区| 欧美成人综合网站| 丰满白嫩尤物一区二区| 中文字幕综合网| 欧美日韩中文精品| 麻豆视频一区二区| 中国色在线观看另类| 色999日韩国产欧美一区二区| 亚洲综合在线观看视频| 日韩一区二区影院| 国产不卡视频一区| 亚洲国产日韩综合久久精品| 日韩亚洲欧美在线观看| www.性欧美| 日韩电影在线看| 欧美激情一区不卡| 欧美日韩综合不卡| 高清成人免费视频| 亚洲成人综合网站| 国产亚洲欧美日韩在线一区| 91免费国产在线观看| 男女激情视频一区| 综合分类小说区另类春色亚洲小说欧美| 欧美色偷偷大香| 国产精品一区在线观看乱码| 亚洲免费在线观看| 精品福利在线导航| 欧美综合一区二区三区| 国产成人一区二区精品非洲| 亚洲成人午夜电影| 欧美激情一区在线| 日韩一区二区三区三四区视频在线观看| 国产91精品在线观看| 水野朝阳av一区二区三区| 国产精品无遮挡| 欧美电影免费提供在线观看| 99re免费视频精品全部| 精彩视频一区二区三区| 亚洲一级片在线观看| 国产精品久久久久三级| 精品久久久久久久久久久久久久久久久 | 视频一区中文字幕| 综合欧美亚洲日本| 久久久久99精品一区| 91精品国产高清一区二区三区 | 捆绑变态av一区二区三区| 亚洲毛片av在线| 国产精品伦一区| 久久精品人人做人人综合 | 综合av第一页| 久久九九久精品国产免费直播| 欧美日韩成人激情| 91啪九色porn原创视频在线观看| 国产精品自拍一区| 久久国产夜色精品鲁鲁99| 天天操天天综合网| 一区二区日韩电影| 一区二区三区四区视频精品免费| 中文字幕国产一区| 国产日韩欧美不卡在线| www日韩大片| 精品粉嫩超白一线天av| 91精品啪在线观看国产60岁| 欧美午夜精品久久久久久孕妇| 成人福利在线看| 成人av动漫网站| 成人毛片在线观看| 懂色av一区二区三区免费看| 国产精品一品视频| 国产成人久久精品77777最新版本| 久久国产精品99久久久久久老狼| 日本成人中文字幕在线视频| 日韩高清欧美激情| 免费成人在线网站| 另类小说色综合网站| 激情丁香综合五月| 国产精品羞羞答答xxdd| 国产高清精品久久久久| 丰满放荡岳乱妇91ww| 本田岬高潮一区二区三区| 91香蕉国产在线观看软件| 91久久线看在观草草青青| 欧美中文字幕一区| 91精品国产一区二区| 精品久久久网站| 中文字幕免费不卡在线| 亚洲欧美日韩国产另类专区| 亚洲一区在线看| 日本不卡一二三| 国产精品99久久久久久有的能看| 成人一区二区三区视频在线观看| va亚洲va日韩不卡在线观看| 在线观看91视频| 欧美一区二区美女| 国产日韩欧美精品电影三级在线| 自拍偷拍国产亚洲| 天堂va蜜桃一区二区三区| 麻豆精品一区二区三区| 国产经典欧美精品| 99re成人精品视频| 欧美一级xxx| 中文字幕一区日韩精品欧美| 午夜天堂影视香蕉久久| 国产黑丝在线一区二区三区| 色综合天天综合网天天狠天天| 欧美日韩美少妇| 久久精品欧美一区二区三区不卡 | 99久久99久久久精品齐齐| 欧美少妇bbb| 国产亚洲一区二区三区在线观看| 亚洲欧美日本在线| 久久超碰97中文字幕| 99久久精品免费看国产| 欧美一区二区三区视频在线| 国产精品欧美经典| 日本女人一区二区三区| 99视频一区二区三区| 日韩欧美一卡二卡| 亚洲激情男女视频| 国产成人精品免费一区二区| 欧美日韩在线播放一区| 久久精品夜色噜噜亚洲a∨| 亚洲一区欧美一区| 成人一区二区三区视频在线观看| 91精选在线观看| 亚洲图片你懂的| 国产精品一区二区免费不卡| 欧美日韩日日摸| 亚洲天堂久久久久久久| 国产一区二区精品久久91| 欧美日韩精品欧美日韩精品一综合| 国产三级精品三级在线专区| 青青草成人在线观看| 色诱亚洲精品久久久久久| 国产亚洲一区字幕| 久久国产福利国产秒拍| 欧美亚洲国产一区二区三区va| 国产偷国产偷亚洲高清人白洁| 日本成人在线一区| 欧美日韩日日骚| 一级中文字幕一区二区| 91在线视频网址| 国产丝袜美腿一区二区三区| 奇米影视一区二区三区| 精品1区2区3区| 亚洲午夜免费视频| 91麻豆免费看片| 亚洲欧洲一区二区在线播放| 国产精品白丝jk黑袜喷水| 精品88久久久久88久久久 | 久久精品国产色蜜蜜麻豆| 7777精品伊人久久久大香线蕉| 亚洲女与黑人做爰| av男人天堂一区| 国产精品美女久久久久aⅴ| 国产剧情一区二区| 久久精品人人做人人爽97| 国内外精品视频| 久久无码av三级| 国产成人免费在线| 国产日韩三级在线| 成a人片国产精品| 成人欧美一区二区三区白人 | 日韩欧美在线1卡| 久久国产精品第一页| 日韩午夜中文字幕| 久久99久久久久| 久久久高清一区二区三区| 国产成a人无v码亚洲福利| 国产精品久久久久久久久免费丝袜| 粉嫩av亚洲一区二区图片| 国产精品久久久久婷婷| 在线中文字幕不卡| 日韩精品一级二级 | 国产调教视频一区| 成人免费视频一区| 亚洲精品videosex极品| 欧美日韩国产在线播放网站| 五月婷婷久久综合| 欧美videossexotv100| 国产成人在线免费| 亚洲视频香蕉人妖| 欧美日本免费一区二区三区| 蜜桃av一区二区在线观看| 国产亚洲女人久久久久毛片| 处破女av一区二区| 亚洲超丰满肉感bbw| 欧美v国产在线一区二区三区| 成人少妇影院yyyy|