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

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

?? ec_inet_macosx.c

?? Ettercap最初設計為交換網上的sniffer
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*    ettercap -- inet utilities -- Module for MacOsX darwin 1.[34]                                                    darwin 5.[012]    Copyright (C) 2001  ALoR <alor@users.sourceforge.net>, NaGA <crwm@freemail.it>    This program is free software; you can redistribute it and/or modify    it under the terms of the GNU General Public License as published by    the Free Software Foundation; either version 2 of the License, or    (at your option) any later version.    This program is distributed in the hope that it will be useful,    but WITHOUT ANY WARRANTY; without even the implied warranty of    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the    GNU General Public License for more details.    You should have received a copy of the GNU General Public License    along with this program; if not, write to the Free Software    Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.    $Id: ec_inet_macosx.c,v 1.14 2002/06/12 16:19:38 alor Exp $*/#include "../../include/ec_main.h"#include "../../include/ec_thread.h"#include "../../include/ec_buffer.h"#include "../../include/ec_inet.h"#include "../../include/ec_inet_forge.h"#include "../../include/ec_inet_structures.h"#include <ctype.h>#include <sys/ioctl.h>#include <fcntl.h>#include <sys/sysctl.h>#include <sys/param.h>#include <sys/timeb.h>#include <sys/file.h>#include <sys/ioctl.h>#include <ctype.h>#include <sys/types.h>#include <sys/time.h>#include <net/bpf.h>#include <sys/socket.h>#include <net/if_dl.h>#include <net/route.h>#include <net/if_types.h>#include <arpa/inet.h>#include <netinet/if_ether.h>#ifdef HAVE_NET_ETHERNET_H   #include <net/ethernet.h>#endifint IpForward_status;      // old ipforward statusint bpf_in_use;int size;int SocketBuffer = -1;static char ARP_BROADCAST[6] = {0x0,0x0,0x0,0x0,0x0,0x0};// protos...int Inet_FindIFace(char *iface);int Inet_CorrectIface(char *iface);int Inet_GetIfaceInfo(char *iface, int *MTU, char *MyMAC, u_long *IP, u_long *NetMask);int Inet_SetPromisc(char *iface);int Inet_OpenRawSock(char *iface);void Inet_CloseRawSock(int sock);int Inet_GetRawPacket(int sock, char *buffer, int MTU, short *type);int Inet_SendRawPacket(int sock, char *buffer, int len);void Inet_SetNonBlock(int sock);void Inet_Restore_ifr(void);void Inet_DisableForwarding(void);void Inet_RestoreForwarding(void);char *Inet_MacFromIP(unsigned long ip);// ----------------------------------------------int Inet_FindIFace(char *iface)     // adapded from pcap_lookupdev{   int fd, minunit, n;   char *cp;   struct ifreq *ifrp, *ifend, *ifnext, *mp;   struct ifconf ifc;   char *buf;   struct ifreq ifr;   unsigned int buf_size;   fd = socket(AF_INET, SOCK_DGRAM, 0);   if (fd < 0)      ERROR_MSG("socket()");   buf_size = 8192;   for (;;) {      buf = malloc (buf_size);      if (buf == NULL)         ERROR_MSG("malloc()");      ifc.ifc_len = buf_size;      ifc.ifc_buf = buf;      memset (buf, 0, buf_size);      if (ioctl(fd, SIOCGIFCONF, (char *)&ifc) < 0 && errno != EINVAL)         ERROR_MSG("ioctl(SIOCGIFCONF)");      if (ifc.ifc_len < buf_size)         break;      free (buf);      buf_size *= 2;   }   ifrp = (struct ifreq *)buf;   ifend = (struct ifreq *)(buf + ifc.ifc_len);   mp = NULL;   minunit = 666;   for (; ifrp < ifend; ifrp = ifnext)   {      const char *endcp;#ifdef HAVE_SOCKADDR_SA_LEN   n = ifrp->ifr_addr.sa_len + sizeof(ifrp->ifr_name);   if (n < sizeof(*ifrp))      ifnext = ifrp + 1;   else      ifnext = (struct ifreq *)((char *)ifrp + n);   if (ifrp->ifr_addr.sa_family != AF_INET)      continue;#else   ifnext = ifrp + 1;#endif      strncpy(ifr.ifr_name, ifrp->ifr_name, sizeof(ifr.ifr_name));      if (ioctl(fd, SIOCGIFFLAGS, (char *)&ifr) < 0)      {         if (errno == ENXIO)            continue;         ERROR_MSG("ioctl(SIOCGIFFLAGS)");      }      DEBUG_MSG("Inet_FindIFace -- check for [%s]", ifr.ifr_name);      /* Must be up and not the loopback */      if ((ifr.ifr_flags & IFF_UP) == 0 || (ifr.ifr_flags & IFF_LOOPBACK) != 0)         continue;      endcp = ifrp->ifr_name + strlen(ifrp->ifr_name);      for (cp = ifrp->ifr_name; cp < endcp && !isdigit(*cp); ++cp)         continue;      if (isdigit (*cp)) {         n = atoi(cp);      } else {         n = 0;      }      if (n < minunit) {         minunit = n;         mp = ifrp;      }   }   close(fd);   if (mp == NULL)   // no device found   {      free(buf);      return -1;   }   strlcpy(iface, mp->ifr_name, sizeof(Options.netiface));   free(buf);   DEBUG_MSG("Inet_FindIFace -- %s found !!", iface);   return 0;}int Inet_CorrectIface(char *iface){   int sock;   struct ifreq ifr;   DEBUG_MSG("Inet_CorrectIface\t\tIface: %s", iface);   sock = socket(AF_INET, SOCK_DGRAM, 0);   if (sock < 0)      ERROR_MSG("socket()");   memset(&ifr, 0, sizeof(ifr));   strncpy(ifr.ifr_name, iface, sizeof(ifr.ifr_name));   if ( ioctl(sock, SIOCGIFFLAGS, &ifr) < 0)             // check for iface   {      close(sock);      return -1;   }   if (!(ifr.ifr_flags & IFF_UP ))                       // check for flag UP   {      close(sock);      return -1;   }   if (ifr.ifr_flags & IFF_LOOPBACK )                    // check for loopback   {      Options.normal = 1;      Error_msg("Ettercap can't be run on loopback device");   }   if ( ioctl(sock, SIOCGIFADDR, &ifr) < 0 )             // check for alias   {      close(sock);      return -1;   }   close(sock);   return 0;}int Inet_GetIfaceInfo(char *iface, int *MTU, char *MyMAC, unsigned long *IP, unsigned long *NetMask){   int sock;   struct ifreq ifr;   sock = socket(PF_INET, SOCK_DGRAM, 0);   memset(&ifr, 0, sizeof(ifr));   strncpy(ifr.ifr_name, iface, sizeof(ifr.ifr_name));   if (MTU != NULL)   {      if ( ioctl(sock, SIOCGIFMTU, &ifr) < 0)      {         DEBUG_MSG("Inet_GetIfaceInfo -- MTU FAILED... assuming 1500");         *MTU = 1500;      }      else         *MTU = ifr.ifr_mtu;   }   if (MyMAC != NULL)   {      int mib[6];      size_t len;      char *buf, *next, *end;      struct if_msghdr *ifm;      struct sockaddr_dl *sdl;      mib[0] = CTL_NET;      mib[1] = AF_ROUTE;      mib[2] = 0;      mib[3] = AF_LINK;      mib[4] = NET_RT_IFLIST;      mib[5] = 0;      if (sysctl(mib, 6, NULL, &len, NULL, 0) < 0)         ERROR_MSG("sysctl()");      if ((buf = (char *)malloc(len)) == NULL )         ERROR_MSG("malloc()");      if (sysctl(mib, 6, buf, &len, NULL, 0) < 0)         ERROR_MSG("sysctl()");      end = buf + len;      for (next = buf ; next < end ; next += ifm->ifm_msglen)      {         ifm = (struct if_msghdr *)next;         if (ifm->ifm_type == RTM_IFINFO)         {            sdl = (struct sockaddr_dl *)(ifm + 1);            if (strncmp(&sdl->sdl_data[0], iface, sdl->sdl_nlen) == 0)            {                memcpy(MyMAC, LLADDR(sdl), ETHER_ADDR_LEN);                break;            }         }      }      free(buf);   }   if (IP != NULL)   {      if ( ioctl(sock, SIOCGIFADDR, &ifr) < 0 )         ERROR_MSG("ioctl(SIOCGIFADDR)");      memcpy((char *)IP, ifr.ifr_addr.sa_data+2, 4);   }   if (NetMask != NULL)   {      if ( ioctl(sock, SIOCGIFNETMASK, &ifr) < 0 )         ERROR_MSG("ioctl(SIOCGIFNETMASK)");      memcpy((char *)NetMask, ifr.ifr_addr.sa_data+2, 4);      if (strcmp(Options.netmask, ""))       // specified on command line         *NetMask = inet_addr(Options.netmask);   }   close(sock);   return 0;}void Inet_SetNonBlock(int sock){   DEBUG_MSG("Inet_SetNonBlock fd = %d", sock);   fcntl(sock, F_SETFL, O_NONBLOCK);}void Inet_CloseRawSock(int sock){   DEBUG_MSG("Inet_CloseRawSock \t wrappered to NULL");   //close(sock);    // the bpf is close when ettercap exits}int Inet_OpenRawSock(char *iface){   int fd, i = 0, type;   char device[sizeof "/dev/bpf0000"];   struct bpf_version bv;   struct ifreq ifr;   char MyMAC[6];   // this BPF will ignore all outgoing packets   static struct bpf_insn insns[] = {      BPF_STMT(BPF_LD+BPF_H+BPF_ABS, 6),           // load mac address [1][2]      BPF_JUMP(BPF_JMP+BPF_JEQ+BPF_K, 0x00, 0, 4), // k is left 0x00 and will be set later... insns[1].k = htons(*(short *)MyMAC);      BPF_STMT(BPF_LD+BPF_H+BPF_ABS, 8),           // load mac address [3][4]      BPF_JUMP(BPF_JMP+BPF_JEQ+BPF_K, 0x00, 0, 2), // if equal check the third part, else jump 2      BPF_STMT(BPF_LD+BPF_H+BPF_ABS, 10),          // load mac address [5][6]      BPF_JUMP(BPF_JMP+BPF_JEQ+BPF_K, 0x00, 1, 0), // if equal this is outgoing ! drop it !      BPF_STMT(BPF_RET|BPF_K, (u_int)-1),          // no filter, passing the wole packet      BPF_STMT(BPF_RET|BPF_K, 0),                  // ignore the packet   };   static struct bpf_program filter = {      sizeof insns / sizeof(insns[0]),      insns   };

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产农村妇女精品| 欧美大片免费久久精品三p | 国产精品三级视频| 国产网站一区二区| 欧洲av在线精品| 国产精品77777| 美女网站色91| 亚洲高清不卡在线观看| 中文字幕日韩一区| www久久精品| 日韩一区二区三区在线观看| 色呦呦网站一区| 成人性视频免费网站| 免费观看在线色综合| 午夜视频一区二区三区| 亚洲欧美二区三区| 国产精品国产自产拍高清av | 亚洲人123区| 欧美激情一区二区在线| 精品国产sm最大网站| 777午夜精品视频在线播放| 欧美专区亚洲专区| 91视频国产资源| 成人激情午夜影院| 国产不卡高清在线观看视频| 精品一区二区久久| 久久国产精品免费| 美女网站在线免费欧美精品| 日韩成人av影视| 亚洲三级在线播放| 亚洲日穴在线视频| 色吧成人激情小说| 不卡av在线网| 成人av第一页| 97久久超碰精品国产| 成a人片国产精品| 国产黄色91视频| 成人av片在线观看| 99久久精品免费| 91官网在线免费观看| 在线观看亚洲一区| 精品视频一区 二区 三区| 欧洲人成人精品| 欧美老女人在线| 日韩免费高清av| 国产精品久久久久天堂| 日韩毛片视频在线看| 亚洲免费观看高清完整版在线| 中文字幕一区二区三区av| 中文字幕亚洲成人| 亚洲一区二区在线观看视频 | 视频一区二区欧美| 日韩va欧美va亚洲va久久| 久久国产夜色精品鲁鲁99| 精品一区中文字幕| 成人视屏免费看| 一本色道久久综合狠狠躁的推荐| 日本高清视频一区二区| 69堂国产成人免费视频| 欧美不卡一区二区三区四区| 久久久精品天堂| 亚洲精品一二三四区| 亚洲v中文字幕| 九九国产精品视频| 成人av电影在线| 欧美日韩视频一区二区| 精品久久久久久久久久久院品网| 中文字幕免费不卡| 亚洲综合在线电影| 久久爱www久久做| 99久久精品国产网站| 欧美日韩精品电影| 久久久三级国产网站| 有坂深雪av一区二区精品| 美女视频黄免费的久久| av电影天堂一区二区在线| 欧美另类一区二区三区| 欧美精品一区二区三区很污很色的 | 国产999精品久久| 欧美三级资源在线| 欧美经典一区二区三区| 亚洲专区一二三| 丁香激情综合五月| 欧美日韩在线三级| 国产日韩综合av| 香蕉乱码成人久久天堂爱免费| 国产激情视频一区二区三区欧美 | 国产日产欧美一区| 亚洲国产欧美日韩另类综合 | 热久久国产精品| 高清视频一区二区| 欧美日韩精品欧美日韩精品一| 精品av久久707| 亚洲一线二线三线视频| 国产成人午夜精品5599| 欧美放荡的少妇| 日韩一区中文字幕| 韩国精品免费视频| 欧美精品在欧美一区二区少妇| 国产精品剧情在线亚洲| 国产综合色在线| 在线观看一区二区精品视频| 国产欧美日韩精品a在线观看| 视频一区欧美精品| 91日韩精品一区| 亚洲午夜久久久久| av色综合久久天堂av综合| 欧美成人一区二区三区片免费| 中文字幕亚洲电影| 国产一区二区三区香蕉| 欧美日韩激情一区二区三区| 中文字幕亚洲精品在线观看 | 国产乱色国产精品免费视频| 欧美日韩免费一区二区三区 | 欧美日韩国产电影| 亚洲啪啪综合av一区二区三区| 国产成人精品三级麻豆| 欧美电视剧在线看免费| 日韩**一区毛片| 欧美疯狂做受xxxx富婆| 亚洲va欧美va天堂v国产综合| 9色porny自拍视频一区二区| 国产三级欧美三级| 国产在线不卡视频| 欧美精品一区二区三区在线| 蜜桃免费网站一区二区三区| 欧美一区二区视频在线观看2022| 亚洲一级二级在线| 欧美日韩国产高清一区二区| 亚洲综合在线五月| 日本丰满少妇一区二区三区| 亚洲色图丝袜美腿| 色综合天天性综合| 伊人婷婷欧美激情| 欧美在线制服丝袜| 亚洲一区二区在线免费观看视频| 欧美性感一区二区三区| 香蕉影视欧美成人| 欧美丰满美乳xxx高潮www| 免费不卡在线视频| 精品99一区二区三区| 国产精品1024久久| 中文字幕一区视频| 欧洲另类一二三四区| 日本网站在线观看一区二区三区| 欧美一区二区啪啪| 久久爱www久久做| 亚洲国产精品黑人久久久| 97久久超碰精品国产| 亚洲无线码一区二区三区| 91精品国产综合久久小美女| 青青草一区二区三区| 久久综合九色综合97婷婷| 国产成人精品www牛牛影视| 成人欧美一区二区三区视频网页 | 亚洲乱码国产乱码精品精小说| 色综合中文字幕| 亚洲成av人片www| 精品免费视频一区二区| 国产aⅴ精品一区二区三区色成熟| 中文字幕在线观看不卡| 欧美三级乱人伦电影| 麻豆国产精品一区二区三区| 国产欧美在线观看一区| 99精品久久只有精品| 亚洲va欧美va国产va天堂影院| 欧美大尺度电影在线| 岛国精品在线播放| 婷婷成人综合网| 国产亚洲综合在线| 久久人人超碰精品| 91麻豆国产自产在线观看| 蜜桃视频在线一区| 国产欧美精品国产国产专区| 欧美亚洲国产一区二区三区 | 99re66热这里只有精品3直播| 一区二区三区不卡视频在线观看| 欧美一三区三区四区免费在线看| 国产老妇另类xxxxx| 亚洲综合在线观看视频| 欧美成人艳星乳罩| 日本丰满少妇一区二区三区| 精品亚洲欧美一区| 洋洋av久久久久久久一区| 精品国产一区二区三区av性色| 色综合久久综合网欧美综合网| 九九久久精品视频| 一区二区高清在线| 中文欧美字幕免费| 欧美一个色资源| 在线欧美一区二区| 国产成人在线视频免费播放| 亚洲国产视频直播| 国产精品久久久久久久久图文区| 在线综合视频播放| 色八戒一区二区三区| 国产91丝袜在线播放0| 日本女优在线视频一区二区| 亚洲美女一区二区三区| 国产日韩欧美a|