国产一级一区二区_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久久夜色精品国产_欧美色网一区二区
欧美一区二区女人| 国产日产亚洲精品系列| 国产精品一区一区三区| 国产日韩欧美在线视频观看| 日韩视频在线一区二区三区| 亚洲国产成人在线播放| 欧美紧缚bdsm在线视频| 一区二区日韩欧美| 欧美丝袜一区二区| 狠狠色综合播放一区二区| 亚洲人被黑人高潮完整版| 亚洲伊人第一页| 狂野欧美一区| 国产精品一区二区欧美| 国产日韩欧美二区| 国产精品久久福利| 欧美视频在线播放| 国模精品娜娜一二三区| 在线亚洲欧美视频| 久久在线免费视频| 国产精品黄色| 亚洲国产欧美不卡在线观看| 午夜视黄欧洲亚洲| 欧美天天综合网| 一本在线高清不卡dvd| 欧美黄色片免费观看| 在线成人av| 久久亚洲综合| 亚洲国产成人一区| 久久伊人精品天天| 亚洲国产成人高清精品| 麻豆av福利av久久av| 国内久久婷婷综合| 久久精品国产精品亚洲精品| 国产一区再线| 久久激情一区| 激情成人综合| 欧美**字幕| 亚洲精品网址在线观看| 欧美日韩高清在线| 亚洲天堂男人| 国产亚洲精久久久久久| 久久久久久一区二区三区| 一区二区在线免费观看| 狂野欧美一区| 亚洲精品一区在线观看香蕉| 欧美日韩亚洲高清| 亚洲欧美在线高清| 一本到12不卡视频在线dvd| 亚洲精品1区| 欧美成人免费网站| 亚洲国产精品久久久久秋霞影院| 牛牛国产精品| 一区二区三区日韩精品| 欧美片网站免费| 亚洲主播在线播放| 黑人一区二区| 欧美大胆人体视频| 亚洲欧美区自拍先锋| 亚洲乱码视频| 国外成人在线视频网站| 激情欧美一区二区三区在线观看| 欧美三级精品| 亚洲欧美成人网| 黑人巨大精品欧美黑白配亚洲| 久热国产精品视频| 亚洲少妇自拍| 伊人久久综合| 国产精品久久久久久久9999| 久久久精品国产99久久精品芒果| 在线日韩日本国产亚洲| 欧美午夜精品理论片a级按摩| 久久成人精品一区二区三区| 亚洲人成亚洲人成在线观看| 国产精品无码专区在线观看| 欧美大秀在线观看| 久久se精品一区二区| 亚洲尤物精选| 玖玖视频精品| 亚洲自拍偷拍网址| 在线看片一区| 国产精品美女久久| 国产欧美一二三区| 欧美日本一道本| 久久精品91久久久久久再现| 亚洲免费电影在线| 在线观看欧美视频| 国产伪娘ts一区| 国产精品欧美在线| 欧美午夜精品久久久久久人妖 | 玖玖玖免费嫩草在线影院一区| 日韩视频在线你懂得| 激情欧美一区二区三区在线观看| 欧美涩涩视频| 欧美—级a级欧美特级ar全黄| 久久精品综合| 午夜激情综合网| 亚洲一区欧美二区| 中文精品视频| 亚洲一区一卡| 亚洲在线黄色| 亚洲女同在线| 欧美一级淫片播放口| 香蕉久久a毛片| 久久只有精品| 在线精品国产欧美| 韩国三级电影一区二区| 国产精品青草综合久久久久99| 欧美黄色aa电影| 欧美在线视频免费播放| 99精品欧美一区| 久久亚洲高清| 国内自拍视频一区二区三区| 午夜精品短视频| 国产日韩欧美综合| 久久大综合网| 一区二区在线视频观看| 老司机精品久久| 亚洲第一免费播放区| 国产日韩欧美在线看| 欧美成年人网站| 蜜臀久久久99精品久久久久久| 91久久国产自产拍夜夜嗨| 亚洲作爱视频| 亚洲精品网址在线观看| 免费不卡视频| 激情欧美国产欧美| 亚洲国产日韩一区二区| 亚洲一区欧美激情| 欧美理论电影在线观看| 欧美二区视频| 欧美日韩一区精品| 国产精品揄拍一区二区| 国产精品视频精品| 激情校园亚洲| 亚洲成色777777女色窝| 亚洲日本中文字幕区| 亚洲高清久久网| 亚洲免费成人av| 亚洲一区二区三区激情| 9人人澡人人爽人人精品| 99国产一区| 欧美亚洲一区在线| 亚洲人成亚洲人成在线观看| 久久久久久色| 国产在线国偷精品产拍免费yy| 国产日韩欧美综合一区| 美日韩免费视频| 欧美成年人网| 国产九色精品成人porny| 韩日午夜在线资源一区二区| 一本久久知道综合久久| 久久精选视频| 麻豆久久精品| 国产丝袜一区二区| 99亚洲一区二区| 免费观看成人鲁鲁鲁鲁鲁视频| 国产精品久久久999| 在线日本成人| 亚洲主播在线观看| 欧美日韩高清免费| 亚洲电影在线看| 欧美1区2区| 欧美在线视频免费播放| 久久免费精品视频| 欧美日韩亚洲视频| 1000部国产精品成人观看| 午夜国产精品视频| 欧美日韩国产专区| 伊人夜夜躁av伊人久久| 欧美二区在线| 影音先锋日韩资源| 欧美在线视频免费播放| 国产欧美日韩伦理| 亚洲欧美日韩精品一区二区| 欧美性事在线| 亚洲免费在线| 国产欧美日韩三级| 午夜精品久久久久久久白皮肤| 欧美人成免费网站| 亚洲美女精品成人在线视频| 欧美成人69av| 亚洲日韩第九十九页| 欧美激情一二三区| 99国产精品一区| 国产精品日本一区二区| 午夜激情一区| 国内久久精品| 欧美不卡一卡二卡免费版| 亚洲国产专区| 欧美三区在线视频| 亚洲视频一起| 国产一区二区三区自拍| 麻豆精品国产91久久久久久| 国产最新精品精品你懂的| 久久成人18免费网站| 一区二区三区自拍| 欧美美女bb生活片| 欧美一区二区网站| 91久久在线观看|