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

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

?? sniffex.c

?? 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");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久夜色精品国产网站| 亚洲国产一区视频| 国产一区二区在线看| 欧美变态口味重另类| 久久99九九99精品| 国产日韩欧美综合在线| 国产盗摄一区二区| 国产精品福利av| 99视频一区二区| 亚洲猫色日本管| 欧美日韩综合一区| 久久精品国产久精国产| 久久九九久精品国产免费直播| 成人激情av网| 亚洲精品久久久久久国产精华液| 欧美图片一区二区三区| 日本欧美一区二区| 国产欧美日韩三级| 欧美四级电影网| 蜜臀久久久久久久| 久久久久久久久蜜桃| 91网址在线看| 久久9热精品视频| 国产精品国产三级国产专播品爱网 | 欧美国产日本韩| 色偷偷成人一区二区三区91| 亚洲成人av一区二区三区| 久久中文字幕电影| 91啪亚洲精品| 久久精品国产第一区二区三区| 高清国产午夜精品久久久久久| 中文一区一区三区高中清不卡| 99精品视频在线观看免费| 亚洲一区二区三区自拍| 欧美一二三四在线| 不卡电影一区二区三区| 视频一区在线播放| 亚洲国产高清不卡| 欧美日韩第一区日日骚| 成人a区在线观看| 婷婷久久综合九色综合绿巨人| 国产无一区二区| 欧美视频一区二区三区在线观看| 国产一二三精品| 五月天亚洲婷婷| 亚洲人123区| 久久久噜噜噜久久人人看| 欧美视频日韩视频在线观看| 国产精品亚洲а∨天堂免在线| 亚洲国产成人高清精品| 成人免费在线视频观看| 亚洲午夜羞羞片| 91精品国产麻豆国产自产在线| av资源网一区| 国产在线不卡视频| 奇米影视一区二区三区小说| 亚洲精品国产一区二区精华液| 26uuu欧美日本| 欧美一区二区女人| 精品1区2区3区| 色偷偷久久人人79超碰人人澡 | 欧美麻豆精品久久久久久| 成人福利视频网站| 国产在线观看一区二区| 另类人妖一区二区av| 日韩av电影免费观看高清完整版| 亚洲精品第一国产综合野| 中文字幕 久热精品 视频在线| 精品久久人人做人人爰| 欧美一级二级三级乱码| 欧美日韩视频在线一区二区| 色婷婷综合久久久| 一本色道久久综合亚洲精品按摩| 99久久精品免费精品国产| 高清成人免费视频| 成+人+亚洲+综合天堂| 岛国av在线一区| 丁香婷婷综合激情五月色| 国产精品白丝av| 国产精品系列在线观看| 国产suv一区二区三区88区| 国产精品亚洲一区二区三区妖精 | 一区二区三区日韩欧美精品 | 国产日韩欧美高清| 久久久久久久综合狠狠综合| 久久精品在这里| 国产三级精品三级在线专区| 国产欧美一区视频| 中文字幕va一区二区三区| 国产精品萝li| 一区二区三区日韩在线观看| 亚洲成人自拍网| 日韩国产成人精品| 国产一区二区视频在线播放| 国产精品99久久久久久有的能看| 成人一二三区视频| 99久久精品99国产精品 | 成人国产免费视频| 91小视频免费观看| 欧美麻豆精品久久久久久| 日韩一二三区视频| 亚洲国产精品t66y| 一区二区欧美国产| 蜜臂av日日欢夜夜爽一区| 国产在线播精品第三| av在线播放成人| 777xxx欧美| 久久久噜噜噜久久中文字幕色伊伊 | 欧美午夜宅男影院| 日韩欧美色综合| 中文字幕av一区 二区| 一区二区在线观看视频在线观看| 亚洲chinese男男1069| 久久99国产乱子伦精品免费| 成人av片在线观看| 91精品久久久久久久久99蜜臂| 26uuu久久综合| 一区二区三区电影在线播| 久久精品国产一区二区三区免费看| 风间由美一区二区av101| 在线亚洲高清视频| 久久午夜国产精品| 一区二区在线观看视频在线观看| 美女一区二区三区| 99久久er热在这里只有精品15| 欧美丰满高潮xxxx喷水动漫| 亚洲色图19p| 亚洲电影激情视频网站| 国产九色sp调教91| 欧美三电影在线| 国产精品欧美综合在线| 午夜影院久久久| 成人国产亚洲欧美成人综合网| 欧美另类videos死尸| 自拍视频在线观看一区二区| 久久av中文字幕片| 欧美日韩一区视频| 国产精品三级电影| 看电视剧不卡顿的网站| 91精彩视频在线| 国产三级精品三级在线专区| 奇米在线7777在线精品| 欧美综合在线视频| 国产精品国产三级国产aⅴ入口| 全国精品久久少妇| 在线观看免费成人| 亚洲欧美怡红院| 国产精品一区二区免费不卡 | 韩国理伦片一区二区三区在线播放| 色综合视频在线观看| 久久精品视频在线免费观看| 麻豆久久久久久久| 欧美日韩成人一区二区| 一区二区三区精品在线| 波多野结衣亚洲| 久久久精品国产99久久精品芒果| 日本成人在线一区| 欧美日韩黄色影视| 亚洲第一狼人社区| 欧美午夜影院一区| 亚洲在线中文字幕| 在线观看国产精品网站| 中文字幕一区二区三区在线播放| 国产一区二区精品久久91| 欧美tickling挠脚心丨vk| 日本色综合中文字幕| 7777精品伊人久久久大香线蕉经典版下载| 一区二区三区欧美日| 91视频国产资源| 一区二区视频在线| 色系网站成人免费| 亚洲国产乱码最新视频 | 欧美国产精品一区二区| 国产乱码一区二区三区| 国产校园另类小说区| 国产激情一区二区三区桃花岛亚洲| 2020日本不卡一区二区视频| 国内一区二区在线| 欧美国产日本韩| 96av麻豆蜜桃一区二区| 亚洲男女毛片无遮挡| 在线亚洲欧美专区二区| 爽好多水快深点欧美视频| 日韩欧美中文字幕制服| 国产伦理精品不卡| 欧美激情在线一区二区三区| 不卡一区在线观看| 一区二区三区在线播| 欧美日韩国产精选| 久久精品国产成人一区二区三区| 精品黑人一区二区三区久久| 国产福利一区二区三区视频在线| 国产精品狼人久久影院观看方式| 色吧成人激情小说| 奇米影视一区二区三区小说| 国产日韩欧美精品电影三级在线| 91网站最新网址| 日本va欧美va欧美va精品| 久久久久久久久久久久久女国产乱| 懂色av一区二区三区蜜臀|