国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關注微信公眾號

Raw Socket(原始套接字)實現Sniffer(嗅探)
2005-12-05   

一. 摘要
Raw Socket: 原始套接字
可以用它來發送和接收 IP 層以上的原始數據包, 如 ICMP, TCP, UDP...

int sockRaw = socket(AF_INET, SOCK_RAW, IPPROTO_RAW);

這樣我們就創建了一個 Raw Socket

Sniffer: 嗅探器
關于嗅探器的原理我想大多數人可能都知道
1. 把網卡置于混雜模式;
2. 捕獲數據包;
3. 分析數據包.

但具體的實現知道的人恐怕就不是那么多了. 好, 現在讓我們用 Raw Socket 的做一個自已的 Sniffer.

二. 把網卡置于混雜模式
在正常的情況下,一個網絡接口應該只響應兩種數據幀:
一種是與自己硬件地址相匹配的數據幀
一種是發向所有機器的廣播數據幀
如果要網卡接收所有通過它的數據, 而不管是不是發給它的, 那么必須把網卡置于混雜模式. 也就是說讓它的思維混亂, 不按正常的方式工作. 用 Raw Socket 實現代碼如下:

setsockopt(sock, IPPROTO_IP, IP_HDRINCL, (char*)&flag, sizeof(flag); //設置 IP 頭操作選項
bind(sockRaw, (PSOCKADDR)&addrLocal, sizeof(addrLocal); //把 sockRaw 綁定到本地網卡上
ioctlsocket(sockRaw, SIO_RCVALL, &dwValue);       //讓 sockRaw 接受所有的數據

flag 標志是用來設置 IP 頭操作的, 也就是說要親自處理 IP 頭: bool flag = ture;
addrLocal 為本地地址: SOCKADDR_IN addrLocal;
dwValue 為輸入輸出參數, 為 1 時執行, 0 時取消: DWORD dwValue = 1;
沒想到這么簡單吧?

三. 捕獲數據包
你的 sockRaw 現在已經在工作了, 可以在局域網內其它的電腦上用 Sniffer 檢測工具檢測一下, 看你的網卡是否處于混雜模式(比如 DigitalBrain 的 ARPKiller).
不能讓他白白的浪費資源啊, 抓包!

recv(sockRaw, RecvBuf, BUFFER_SIZE, 0); //接受任意數據包

#define BUFFER_SIZE 65535
char RecvBuf[BUFFER_SIZE];
越來越發現 Sniffer 原來如此的簡單了, 這么一個函數就已經完成抓取數據包的任務了.

四. 分析數據包
這回抓來的包和平常用 Socket 接受的包可就不是一回事兒了, 里面包含 IP, TCP 等原始信息. 要分析它首先得知道這些結構.
數據包的總體結構:
----------------------------------------------
| ip header | tcp header(or x header) | data |
----------------------------------------------

IP header structure:
4    8    16                    32 bit
|--------|--------|----------------|--------------------------------|
| Ver  | IHL  |Type of service |     Total length     |
|--------|--------|----------------|--------------------------------|
| Identification |   Flags   |     Fragment offset    |
|--------|--------|----------------|--------------------------------|
| Time to live  |  Protocol  |     Header checksum    |
|--------|--------|----------------|--------------------------------|
|             Source address              |
|--------|--------|----------------|--------------------------------|
|            Destination address             |
|--------|--------|----------------|--------------------------------|
|            Option + Padding              |
|--------|--------|----------------|--------------------------------|
|                Data                |
|--------|--------|----------------|--------------------------------|

TCP header structure:
16                32 bit
|--------------------------------|--------------------------------|
|     Source port      |    Destination port    |
|--------------------------------|--------------------------------|
|             Sequence number             |
|--------------------------------|--------------------------------|
|           Acknowledgement number           |
|--------------------------------|--------------------------------|
| Offset | Resrvd |U|A|P|R|S|F|      Window       |
|--------------------------------|--------------------------------|
|      Checksum       |    Urgent pointer     |
|--------------------------------|--------------------------------|
|             Option + Padding            |
|--------------------------------|--------------------------------|
|               Data                |
|--------------------------------|--------------------------------|

五. 實現 Sniffer
OK!
現在都清楚了, 還等什么.
下面是我用 BCB6 寫的一個 Simple Sniffer 的代碼, 僅供參考.
(需要在工程文件里加入WS2_32.LIB這個文件)
//*************************************************************************//
//* CPP File: WMain.cpp
//* Simple Sniffer by shadowstar
//* http://shadowstar.126.com/
//*************************************************************************//
#include <vcl.h>
#pragma hdrstop

#include <winsock2.h>
#include <ws2tcpip.h>
#include <mstcpip.h>
#include <netmon.h>
#include "WMain.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TMainForm *MainForm;
//---------------------------------------------------------------------------
__fastcall TMainForm::TMainForm(TComponent* Owner)
: TForm(Owner)
{
WSADATA WSAData;
BOOL  flag  = true;
int   nTimeout = 1000;
char  LocalName[16];
struct hostent *pHost;

//檢查 Winsock 版本號
if (WSAStartup(MAKEWORD(2, 2), &WSAData) != 0)
throw Exception("WSAStartup error!");

//初始化 Raw Socket
if ((sock = socket(AF_INET, SOCK_RAW, IPPROTO_RAW)) == INVALID_SOCKET)
throw Exception("socket setup error!");

//設置IP頭操作選項
if (setsockopt(sock, IPPROTO_IP, IP_HDRINCL, (char*)&flag, sizeof(flag)) == SOCKET_ERROR)
throw Exception("setsockopt IP_HDRINCL error!");

//獲取本機名
if (gethostname((char*)LocalName, sizeof(LocalName)-1) == SOCKET_ERROR)
throw Exception("gethostname error!");

//獲取本地 IP 地址
if ((pHost = gethostbyname((char*)LocalName)) == NULL)
throw Exception("gethostbyname error!");

addr_in.sin_addr  = *(in_addr *)pHost->h_addr_list[0]; //IP
addr_in.sin_family = AF_INET;
addr_in.sin_port  = htons(57274);

//把 sock 綁定到本地地址上
if (bind(sock, (PSOCKADDR)&addr_in, sizeof(addr_in)) == SOCKET_ERROR)
throw Exception("bind error!");

iSortDirection = 1;
}
//---------------------------------------------------------------------------
__fastcall TMainForm::~TMainForm()
{
WSACleanup();
}
//---------------------------------------------------------------------------

void __fastcall TMainForm::btnCtrlClick(TObject *Sender)
{
TListItem *Item;
DWORD dwValue;
int nIndex = 0;

if (btnCtrl->Caption == "&Start")
{
dwValue = 1;
//設置 SOCK_RAW 為SIO_RCVALL,以便接收所有的IP包
if (ioctlsocket(sock, SIO_RCVALL, &dwValue) != 0)
throw Exception("ioctlsocket SIO_RCVALL error!");
bStop = false;
btnCtrl->Caption = "&Stop";
lsvPacket->Items->Clear();
}
else
{
dwValue = 0;
bStop = true;
btnCtrl->Caption = "&Start";
//設置SOCK_RAW為SIO_RCVALL,停止接收
if (ioctlsocket(sock, SIO_RCVALL, &dwValue) != 0)
throw Exception("WSAIoctl SIO_RCVALL error!");
}

while (!bStop)
{
if (recv(sock, RecvBuf, BUFFER_SIZE, 0) > 0)
{
nIndex++;

ip = *(IP*)RecvBuf;
tcp = *(TCP*)(RecvBuf + (ip.HdrLen & IP_HDRLEN_MASK));

Item = lsvPacket->Items->Add();
Item->Caption = nIndex;
Item->SubItems->Add(GetProtocolTxt(ip.Protocol));
Item->SubItems->Add(inet_ntoa(*(in_addr*)&ip.SrcAddr));
Item->SubItems->Add(inet_ntoa(*(in_addr*)&ip.DstAddr));
Item->SubItems->Add(tcp.SrcPort);
Item->SubItems->Add(tcp.DstPort);
Item->SubItems->Add(ntohs(ip.TotalLen));
}
Application->ProcessMessages();
}  
}
//---------------------------------------------------------------------------

AnsiString __fastcall TMainForm::GetProtocolTxt(int Protocol)
{
switch (Protocol)
{
case IPPROTO_ICMP :      //1        /* control message protocol */
return PROTOCOL_STRING_ICMP_TXT;
case IPPROTO_TCP :      //6        /* tcp */
return PROTOCOL_STRING_TCP_TXT;
case IPPROTO_UDP :      //17       /* user datagram protocol */
return PROTOCOL_STRING_UDP_TXT;
default :
return PROTOCOL_STRING_UNKNOWN_TXT;
}
}
//---------------------------------------------------------------------------


//*************************************************************************//
//* Header File: WMain.h for WMain.cpp class TMainForm
//*************************************************************************//
//---------------------------------------------------------------------------

#ifndef WMainH
#define WMainH
//---------------------------------------------------------------------------
#define BUFFER_SIZE 65535

#include <Classes.hpp>
#include <Controls.hpp>
#include <StdCtrls.hpp>
#include <Forms.hpp>
#include <ComCtrls.hpp>
#include <ExtCtrls.hpp>
#include <winsock2.h>
#include "netmon.h"


//---------------------------------------------------------------------------
class TMainForm : public TForm
{
__published: // IDE-managed Components
TPanel *Panel1;
TButton *btnCtrl;
TListView *lsvPacket;
TLabel *Label1;
void __fastcall btnCtrlClick(TObject *Sender);
void __fastcall lsvPacketColumnClick(TObject *Sender,
TListColumn *Column);
void __fastcall lsvPacketCompare(TObject *Sender, TListItem *Item1,
TListItem *Item2, int Data, int &Compare);
void __fastcall Label1Click(TObject *Sender);
private: // User declarations
AnsiString __fastcall GetProtocolTxt(int Protocol);
public: // User declarations
SOCKET   sock;
SOCKADDR_IN addr_in;
IP     ip;
TCP     tcp;
PSUHDR   psdHeader;
char    RecvBuf[BUFFER_SIZE];
bool    bStop;

int iSortDirection;
int iColumnToSort;

__fastcall TMainForm(TComponent* Owner);
__fastcall ~TMainForm();
};
//---------------------------------------------------------------------------
extern PACKAGE TMainForm *MainForm;
//---------------------------------------------------------------------------
#endif

偷了個懶, IP, TCP 頭及一些宏定義用了 netmon.h 的頭, 這個文件在 BCB6 的 include 目錄下可以找得到, 其中與本程序相關內容如下:

//*************************************************************************//
//* Header File: netmon.h
//*************************************************************************//
//
// IP Packet Structure
//
typedef struct _IP
{
union
{
BYTE  Version;
BYTE  HdrLen;
};
BYTE ServiceType;
WORD TotalLen;
WORD ID;
union
{
WORD  Flags;
WORD  FragOff;
};
BYTE TimeToLive;
BYTE Protocol;
WORD HdrChksum;
DWORD  SrcAddr;
DWORD  DstAddr;
BYTE Options[0];
} IP;

typedef IP * LPIP;
typedef IP UNALIGNED * ULPIP;

//
// TCP Packet Structure
//
typedef struct _TCP
{
WORD SrcPort;
WORD DstPort;
DWORD SeqNum;
DWORD AckNum;
BYTE DataOff;
BYTE Flags;
WORD Window;
WORD Chksum;
WORD UrgPtr;
} TCP;

typedef TCP *LPTCP;
typedef TCP UNALIGNED * ULPTCP;

// upper protocols
#define PROTOCOL_STRING_ICMP_TXT    "ICMP"
#define PROTOCOL_STRING_TCP_TXT    "TCP"
#define PROTOCOL_STRING_UDP_TXT    "UDP"
#define PROTOCOL_STRING_SPX_TXT    "SPX"
#define PROTOCOL_STRING_NCP_TXT    "NCP"

#define PROTOCOL_STRING_UNKNOW_TXT   "UNKNOW"


這個文件也有人聲稱沒有.
//*************************************************************************//
//* Header File: mstcpip.h
//*************************************************************************//
// Copyright (c) Microsoft Corporation. All rights reserved.
#if _MSC_VER > 1000
#pragma once
#endif

/* Argument structure for SIO_KEEPALIVE_VALS */

struct tcp_keepalive {
u_long onoff;
u_long keepalivetime;
u_long keepaliveinterval;
};

// New WSAIoctl Options

#define SIO_RCVALL      _WSAIOW(IOC_VENDOR,1)
#define SIO_RCVALL_MCAST   _WSAIOW(IOC_VENDOR,2)
#define SIO_RCVALL_IGMPMCAST _WSAIOW(IOC_VENDOR,3)
#define SIO_KEEPALIVE_VALS  _WSAIOW(IOC_VENDOR,4)
#define SIO_ABSORB_RTRALERT  _WSAIOW(IOC_VENDOR,5)
#define SIO_UCAST_IF     _WSAIOW(IOC_VENDOR,6)
#define SIO_LIMIT_BROADCASTS _WSAIOW(IOC_VENDOR,7)
#define SIO_INDEX_BIND    _WSAIOW(IOC_VENDOR,8)
#define SIO_INDEX_MCASTIF   _WSAIOW(IOC_VENDOR,9)
#define SIO_INDEX_ADD_MCAST  _WSAIOW(IOC_VENDOR,10)
#define SIO_INDEX_DEL_MCAST  _WSAIOW(IOC_VENDOR,11)

// Values for use with SIO_RCVALL* options
#define RCVALL_OFF       0
#define RCVALL_ON       1
#define RCVALL_SOCKETLEVELONLY 2

現在我們自已的 Sniffer 就做好了, Run, Start......哇, 這么多數據包, 都是從這一臺機器上發出的, 它在干什么? 原來 Adminstrator 密碼為空, 中了尼姆達病毒!

六. 小結
優點: 實現簡單, 不需要做驅動程序就可實現抓包.
缺點: 數據包頭不含幀信息, 不能接收到與 IP 同層的其它數據包, 如 ARP, RARP...
這里提供的程序僅僅是一個 Sniffer 的例子, 沒有對數據包進行進一步的分析. 寫此文的目的在于熟悉Raw Socket 編程方法, 了解 TCP/IP 協議結構原理以及各協議之間的關系.


熱詞搜索:

上一篇:用SNIFFER透視動態域名
下一篇:Sniffer-黑客們最常用的入侵手段

分享到: 收藏
国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区
激情欧美一区二区| 欧美mv日韩mv国产网站| 亚洲免费观看在线视频| 日韩美女啊v在线免费观看| 亚洲高清视频在线| 日韩中文字幕1| 老司机免费视频一区二区| 国产一区不卡在线| 在线影院国内精品| 日韩精品一区二区三区在线观看 | 欧美mv日韩mv国产网站| 激情综合色综合久久| 色老汉一区二区三区| 亚洲国产精品欧美一二99| 日韩免费在线观看| 色综合久久久久网| 中文字幕一区二区三区四区不卡 | 亚洲愉拍自拍另类高清精品| 国产一区二区三区免费| 最新日韩在线视频| 日韩欧美一区二区免费| 91在线观看视频| 国产女人aaa级久久久级 | 国产精品综合在线视频| 欧美一区二区三区在| 性做久久久久久久久| 色呦呦一区二区三区| 久久99精品国产.久久久久久 | 色综合中文字幕| 中文字幕免费观看一区| 久久99国产精品久久| 亚洲一区在线观看视频| 中文字幕av不卡| 欧美一级日韩一级| 欧美在线观看视频在线| 亚洲一区影音先锋| 国产日韩影视精品| 欧美xxxxx裸体时装秀| 欧美三日本三级三级在线播放| 18欧美亚洲精品| 国产午夜三级一区二区三| 国产精品1区2区3区| 日韩精品一级二级| 丝袜诱惑亚洲看片| 午夜婷婷国产麻豆精品| 日韩美女天天操| 欧美一区二区久久| 欧美精品丝袜中出| 精品一区二区免费在线观看| 亚洲成人激情av| 亚洲一区自拍偷拍| 亚洲一区二区三区视频在线播放| 国产精品麻豆网站| 在线免费一区三区| 色综合久久中文字幕| 99re亚洲国产精品| 天天综合网 天天综合色| 亚洲激情校园春色| 欧美一二三区精品| 99国产欧美另类久久久精品| 顶级嫩模精品视频在线看| 中文字幕在线播放不卡一区| 国产日韩综合av| 国产精品看片你懂得| 91精品啪在线观看国产60岁| 久久99久久99小草精品免视看| 免费成人小视频| 国产精品天美传媒| 国产精品久久久99| 一区二区三区欧美日| 精品福利一二区| 91农村精品一区二区在线| 不卡av在线免费观看| 免费一级片91| 极品瑜伽女神91| 成人一道本在线| 日韩va欧美va亚洲va久久| 国产情人综合久久777777| 国产日韩精品一区二区浪潮av| 国产精品久久久久久久久图文区 | 99免费精品视频| 国产在线视频一区二区| 国产麻豆成人传媒免费观看| 国产成人免费9x9x人网站视频| 亚洲在线中文字幕| 亚洲aⅴ怡春院| 精品在线观看免费| 成人福利视频网站| 欧美色网站导航| 91在线视频观看| 欧美福利一区二区| 久久久精品蜜桃| 久久综合色鬼综合色| 欧美日韩精品电影| av亚洲精华国产精华精| 91传媒视频在线播放| 精品国产污网站| 亚洲人成在线观看一区二区| 久久精品国产第一区二区三区| 成人av在线资源| 日韩精品一区在线观看| 国产精品国产三级国产三级人妇 | 色视频欧美一区二区三区| 精品少妇一区二区三区| 亚洲精品五月天| 激情欧美一区二区| 91精品一区二区三区久久久久久| 国产日韩欧美不卡| 国产在线播精品第三| 欧美日韩一区高清| 亚洲免费资源在线播放| 国产精品一区二区在线观看不卡| 欧美日韩精品三区| 亚洲蜜臀av乱码久久精品| 国产一区二区精品久久99| 欧美蜜桃一区二区三区| 亚洲视频你懂的| 粉嫩嫩av羞羞动漫久久久| 日韩小视频在线观看专区| 亚洲精品写真福利| 91小视频在线| 中文字幕精品三区| 懂色av一区二区在线播放| 久久久久亚洲蜜桃| 精品一区二区三区av| 91麻豆精品国产91久久久久久久久| 国产精品九色蝌蚪自拍| 成人激情图片网| 欧美韩国一区二区| 成人免费看视频| 国产精品国产自产拍高清av| 成人午夜电影小说| 国产精品女同一区二区三区| 国产成人综合亚洲网站| 久久久精品天堂| 懂色av一区二区三区免费观看| 国产人伦精品一区二区| 国产精品一区2区| 久久综合九色综合97婷婷| 久久精品国产99| 久久先锋资源网| 国产99久久久精品| 亚洲天堂免费看| 欧美性极品少妇| 亚洲福利一二三区| 91精品国产入口在线| 激情图区综合网| 国产精品视频第一区| 91蜜桃视频在线| 午夜伊人狠狠久久| 日韩一二三区视频| 国产精品99久久久久久久女警 | 久久人人97超碰com| 国产精品一区二区视频| 国产免费观看久久| 在线观看日产精品| 免费在线欧美视频| 国产欧美日韩视频在线观看| 在线看不卡av| 久久99精品网久久| 国产精品乱码一区二区三区软件 | 国产精品一区二区久久精品爱涩| 亚洲三级在线观看| 日韩一区二区中文字幕| 91视频在线观看| 毛片av中文字幕一区二区| 色网站国产精品| 日韩av在线发布| 国产精品亲子伦对白| 欧美日韩成人在线| 99热这里都是精品| 免费看欧美女人艹b| 中文一区二区完整视频在线观看| 在线免费不卡电影| 大胆欧美人体老妇| 日韩激情视频在线观看| 国产精品剧情在线亚洲| 欧美成人精品福利| 欧美在线制服丝袜| 成人国产一区二区三区精品| 日本不卡一二三| 亚洲激情五月婷婷| 国产精品盗摄一区二区三区| 欧美videos中文字幕| 欧美三级日本三级少妇99| 成人午夜在线视频| 久久国产精品露脸对白| 亚洲第一激情av| 亚洲精品成人悠悠色影视| 久久人人爽爽爽人久久久| 日韩一区二区三区四区五区六区| 色综合欧美在线| 国产99久久久国产精品| 精品中文字幕一区二区| 青青青伊人色综合久久| 日韩成人免费电影| 日韩中文字幕av电影| 午夜精品福利视频网站| 亚洲国产精品一区二区www在线 | 一区二区三区资源|