青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

jeromewen

努力中
隨筆 - 9, 文章 - 0, 評論 - 22, 引用 - 0
數據加載中……

Nids.h詳細注釋

#ifndef _NIDS_NIDS_H

#define _NIDS_NIDS_H

#define NIDS_MAJOR 1???? /* 主版本號 */

#define NIDS_MINOR 20??? /* 次版本號 */

#include <sys/types.h>

enum

{

? NIDS_WARN_IP = 1,????? /* 表示 IP 數據包異常 */

? NIDS_WARN_TCP,???????? /* 表示 TCP 數據包異常 */

? NIDS_WARN_UDP,??????? /* 表示 UDP 數據包異常 */

? NIDS_WARN_SCAN ?????? /* 表示有掃描攻擊發生 */

};

?

enum

{

? NIDS_WARN_UNDEFINED = 0,???? /* 表示未定義 */

? NIDS_WARN_IP_OVERSIZED,?????? /* 表示 IP 數據包超長 */

? NIDS_WARN_IP_INVLIST,????????????? /* 表示無效的碎片隊列 */

? NIDS_WARN_IP_OVERLAP,?????????? /* 表示發生重疊 */

? NIDS_WARN_IP_HDR,?????????? /* 表示無效 IP 首部 ,IP 數據包發生異常 */

? NIDS_WARN_IP_SRR,???????????? /* 表示源路由 IP 數據包 */

? NIDS_WARN_TCP_TOOMUCH,??? /* 表示 TCP 數據個數太多 , 因為在 Libnids 中在同一時刻捕獲的 TCP 個數最大值為 TCP 連接參數的哈西表長度的 3/4*/

? NIDS_WARN_TCP_HDR,???????????????? /* 表示無效 TCP 首部 ,TCP 數據包發生異常 */

? NIDS_WARN_TCP_BIGQUEUE,???? /* 表示 TCP 接受的隊列數據過多 */

? NIDS_WARN_TCP_BADFLAGS ???? /* 表示錯誤標記 */

};

?

/*Libnids 狀態描述的是連接的邏輯狀態 , 真正的 TCP 連接狀態有 11 .

?*TCP_ESTABLISHED?????? TCP 連接建立 , 開始傳輸數據

?*TCP_SYN_SEND???????????? 主動打開

?*TCP_SYN_RECV???????????? 接受 SYN

?*TCP_FIN_WAIT1

?*TCP_FIN_WAIT2

?*TCP_TIME_WAIT

?*TCP_CLOSE

?*TCP_CLOSE_WAIT

?*TCP_LAST_ACK

?*TCP_LISTEN

?*TCP_CLOSING

?*/

#define NIDS_JUST_EST 1?????????? /* 表示 TCP 連接建立 , 在此狀態下就可以決定是否對此 TCP 連接進行數據分析 , 可以決定是否捕獲 TCP 客戶端接收的數據 ,TCP 服務端接收的數據 ,TCP 客戶端接收的緊急數據或者 TCP 客戶端接收的緊急數據 */

#define NIDS_DATA 2????????????????? /* 表示接收數據的狀態 , 在這個狀態可以判斷是否有新的數據到達 , 如果有就可以把數據存儲起來 , 可以在這個狀態之中來分析 TCP 傳輸的數據 , 此數據就存儲在 half_stream 數據接口的緩存之中 */

#define NIDS_CLOSE 3???????????????? /* 表示 TCP 連接正常關閉 */

#define NIDS_RESET 4???????????????? /* 表是 TCP 連接被重置關閉 */

#define NIDS_TIMED_OUT 5???? /* 表示由于超時 TCP 連接被關閉 */

#define NIDS_EXITING?? 6?????? /* 表示 Libnids 正在退出 , 在這個狀態下可以最后一次使用存儲在 half_stream 數據結構中的緩存數據 */

?

/* 校驗和 */

#define NIDS_DO_CHKSUM? 0????????? /* 表示告訴 Libnids 要計算校驗和 */

#define NIDS_DONT_CHKSUM 1?????? /* 表示告訴 Libnids 不要計算校驗和 */

?

struct tuple4???????????????? /* 描述一個地址端口對 , 它表示發送發 IP 和端口以及接收方 IP 和端口 , 適用 TCP,UDP*/

{

? u_short source;???????? /* IP 地址的端口號 */

? u_short dest;??????????? /* 目的 IP 地址的端口號 */

? u_int saddr;????????????? /* IP 地址 */

? u_int daddr;????????????? /* 目的 IP 地址 */

};

?

struct half_stream??????? /* 描述在 TCP 連接中一端的所有信息 , 可以是客戶端 , 也可以是服務端 */

{

? char state;???????????????? /* 表示套接字的狀態 , 也就是 TCP 的狀態 */

? char collect;????????????? /* 可以表示有數據到達 , 此數據存放在 data 成員中 , 也可以表示不存儲此數據到 data , 此數據忽略 . 如果大于 0 就存儲 , 否則就忽略 */

? char collect_urg;?????? /* 可以表示有緊急數據到達 , 此數據就存放在 urgdata , 也可以表示不存儲此數據到 urgdata , 此速數據忽略 . 如果大于 0 就存儲 , 否則就忽略 */

?

? char *data;??????????????? /* 用戶存儲正常接受到的數據 */

? int offset;????????????????? /* 表示存儲在 data 中數據的第一個字節的偏移量 */

? int count;????????????????? /* 表示從 TCP 連接開始已經存儲到 data 中的數據的字節數 */

? int count_new;???????? /* 有多少新的數據存儲到 data , 如果為 0, 則表示沒有新的數據到達 */

? int bufsize;

? int rmem_alloc;

?

? int urg_count;? /* 用來存儲緊急數據 */

? u_int acked;????

? u_int seq;

? u_int ack_seq;

? u_int first_data_seq;

? u_char urgdata;

? u_char count_new_urg;???? /* 表示有新的緊急數據到達 , 如果為 0 表示沒有新的緊急數據 */

? u_char urg_seen;??????

? u_int urg_ptr;

? u_short window;?????

? u_char ts_on;

? u_char wscale_on;

? u_int curr_ts;

? u_int wscale;

? struct skbuff *list;

? struct skbuff *listtail;

};

?

struct tcp_stream???????? /* 描述一個 TCP 連接的所有信息 */

{

? struct tuple4 addr;

? char nids_state;

? struct lurker_node *listeners;

? struct half_stream client;?? /* 表示客戶端信息 */

? struct half_stream server;? /* 表示服務端信息 */

? struct tcp_stream *next_node;

? struct tcp_stream *prev_node;

? int hash_index;

? struct tcp_stream *next_time;

? struct tcp_stream *prev_time;

? int read;

? struct tcp_stream *next_free;

};

?

struct nids_prm??????????? /* 描述了 Libnids 的一些全局參數信息 */

{

? int n_tcp_streams;?? /* 表示哈西表大小 , 此哈西表用來存放 tcp_stream 數據結構 , 默認值 1040. 在同一時刻 Libnids 捕獲的 TCP 數據包的最大個數必須是此參數值的 3/4*/

? int n_hosts;????????????? /* 表示哈西表的大小 , 此哈西表用來存儲 IP 碎片信息的 , 默認值為 256*/

? char *device;?? /* 表示網絡接口 ,Libnids 將在此網絡接口上捕獲數據 , 默認值為 NULL. 這樣 Libnids 將使用 pcap_lookupdev 來查找可以用的網絡接口 . 如果其值為 all, 表示捕獲所有網絡接口的數據 */

? char *filename;???????? /* 表示用來存儲網絡數據的捕獲文件 , 此文件的類型必須與 Libpcap 類型一致 , 如果設置了文件 , 與此同時就應該設置 device NULL, 默認值為 NULL*/

? int sk_buff_size;????? /* 表示的是數據接口 sk_buff 的大小 .sk_buff Linux 內核中一個重要的數據結構 , 是用來進行數據包排隊操作的 , 默認值為 168*/

? int dev_addon;????????? /* 表示在數據結構 sk_buff 中用于網絡接口上信息的字節數 . 如果是 -1( 默認值 ), 那么 Libnids 會根據不同的網絡接口進行修正 */

? void (*syslog) ();????? /* 是一個函數指針 , 默認值為 nids_syslog() 函數 . syslog 函數中可以檢測入侵攻擊 , 如網絡掃描攻擊 , 也可以檢測一些異常情況 , 如無效 TCP 標記 */

? int syslog_level;?????? /* 表示日志等級 , 默認值是 LOG_ALERT*/

? int scan_num_hosts;????????? /* 表示一個哈西表的大小 ,( 此哈西表用來存儲端口掃描信息 ) 表示 Libnids 將要檢測的同時掃描的端口數據 . 如果其值為 0,Libnids 將不提供端口掃描功能 . 默認值 256*/

? int scan_delay;???????? /* 表示在掃描檢測中 , 倆端口掃描的間隔時間 , 以毫秒來計算 , 缺省值為 3000*/

? int scan_num_ports;????????? /* 表示相同源地址必須掃描的 TCP 端口數目 , 默認值為 10*/

? void (*no_mem) (char *);? /* 是一個函數指針 , Libnids 發生內存溢出時被調用 */

? int (*ip_filter) ();????? /* 是一個函數指針 , 此函數可以用來分析 IP 數據包 , 當有 IP 數據包到達時 , 此函數就被調用 . 如果此函數返回非零值 , 此數據包就被處理 ; 如果返回零 , IP 數據包就被丟棄 . 默認值為 nids_ip_filter 函數 , 總是返回 1.*/

? char *pcap_filter;???? /* 表示過濾規則 , Libpcap 的過濾規則 , 默認值為 NULL, 表示捕獲所有數據包 . 可以在此設置過濾規則 , 只捕獲感興趣的開發包 */

? int promisc;????????????? /* 表示網卡模式 , 如果是非零 , 就把此網卡設置為混雜模式 ; 否則 , 設為非混雜模式 . 默認值為 1*/

? int one_loop_less;??? /* 初始值為 0*/

? int pcap_timeout;???? /* 表示捕獲數據返回的時間 , 以毫秒計算 . 實際上它表示的就是 Libpcap 函數中的 pcap_open_live 函數的 timeout 參數 , 默認值 1024*/

};

?

/*

?* 返回值 : 調用成功返回 1, 失敗返回 0

?* ? :

?* ? : Libnids 初始化 , 這是所有設計基于 Libnids 的程序最開始調用的函數 . 它的主要內容包括打開網絡接口 , 打開文件 , 編譯過濾規則 ,

?*???? 判斷網絡鏈路層類型 , 進行必要的初始化工作

?*/

int nids_init (void);

/*

?* 返回值 :

?* ? : 回調函數名字

?* ? : 注冊一個能夠檢測所有 IP 數據包的回調函數 , 包括 IP 碎片 .e.g

? ?????? nids_register_ip_frag(ip_frag_function);

? ?????? void ip_frag_function(struct ip * a_packet,int len)

? ?????? a_packet 表示接收的 IP 數據包 len 表示接收的數據包長度

? ?????? 此回調函數可以檢測所有的 IP 數據包 , 包括 IP 碎片

?*/

void nids_register_ip_frag (void (*));????? /**/

/*

?* 返回值 :

?* ? : 回調函數名字

?* ? : 注冊一個回調函數 , 此回調函數可以接收正常的 IP 數據包 .e.g

? ?????? nids_register_ip_frag(ip_frag_function);

? ?????? void ip_frag_function(struct ip * a_packet)

? ?????? a_packet 表示接收的 IP 數據包

? ?????? 此回調函數可以接收正常的 IP 數據包 , 并在此函數中對捕獲數到的 IP 數據包進行分析 .

?*/

void nids_register_ip (void (*));???? /**/

/*

?* 返回值 :

?* ? : 回調函數

?* ? : 注冊一個 TCP 連接的回調函數 . 回調函數的類型定義如下 :

? ?????? ?void tcp_callback(struct tcp_stream * ns,void ** param)

? ?????? ?ns 表示一個 TCP 連接的所有信息 , param 表示要傳遞的參數信息 , 可以指向一個 TCP 連接的私有數據

? ?????? ? 此回調函數接收的 TCP 數據存放在 half_stream 的緩存中 , 應該馬上取出來 , 一旦此回調函數返回 , 此數據緩存中存儲的數據就不存在

? ?????? ? .half_stream 成員 offset 描述了被丟棄的數據字節數 . 如果不想馬上取出來 , 而是等到存儲一定數量的數據之后再取出來 , 那么可

? ?????? ? 以使用函數 nids_discard(struct tcp_stream * ns, int num_bytes) 來處理 . 這樣回調函數返回時 ,Libnids 將丟棄緩存數據之前

? ?????? ? num_bytes 字節的數據 . 如果不調用 nids_discard() 函數 , 那么緩存數據的字節應該為 count_new 字節 . 一般情況下 , 緩存中的數據

? ?????? ? 應該是 count-offset 字節

?*/

void nids_register_tcp (void (*));

/*

?* 返回值 :

?* ? : 回調函數

?* ? : 注冊一個分析 UDP 協議的回調函數 , 回調函數的類型定義如下 :

? ?????? ?void udp_callback(struct tuple4 * addr,char *buf,int len,struct ip *iph)

? ?????? ?addr 表示地址端口信息 buf 表示 UDP 協議負載的數據內容 len 表是 UDP 負載數據的長度 iph 表示一個 IP 數據包 , 包括 IP 首部 ,UDP 首部以及 UDP 負載內容

?*/

void nids_register_udp (void (*));

/*

?* 返回值 :

?* ? : 表示一個 TCP 連接

?* ? : 終止 TCP 連接 . 它實際上是調用 Libnet 的函數進行構造數據包 , 然后發送出去

?*/

void nids_killtcp (struct tcp_stream *);

/*

?* 返回值 :

?* ? : 參數 1 一個 TCP 連接 參數 2 個數

?* ? : 丟棄參數 2 字節 TCP 數據 , 用于存儲更多的數據

?*/

void nids_discard (struct tcp_stream *, int);

/*

?* 返回值 :

?* ? :

?* ? : 運行 Libnids, 進入循環捕獲數據包狀態 . 它實際上是調用 Libpcap 函數 pcap_loop() 來循環捕獲數據包

?*/

void nids_run (void);

/*

?* 返回值 : 調用成功返回文件描述符 , 失敗返回 -1

?* ? :

?* ? : 獲得文件描述符號

?*/

int nids_getfd (void);

/*

?* 返回值 : 調用成功返回個數 , 失敗返回負數

?* ? : 表示捕獲數據包的個數

?* ? : 調用 Libpcap 中的捕獲數據包函數 pcap_dispatch()

?*/

int nids_dispatch (int);

/*

?* 返回值 : 調用成功返回 1, 失敗返回 0

?* ? :

?* ? : 調用 Libpcap 中的捕獲數據包函數 pcap_next()

?*/

int nids_next (void);

?

extern struct nids_prm nids_params;?????? /*libnids.c 定以了一個全部變量 , 其定義和初始值在 nids_params*/

extern char *nids_warnings[];????????

extern char nids_errbuf[];

extern struct pcap_pkthdr *nids_last_pcap_header;

?

struct nids_chksum_ctl {????? /* 描述的是計算校驗和 , 用于決定是否計算校驗和 */

???????? u_int netaddr;?????????????? /* 表示地址 */

???????? u_int mask;?????????????????? /* 表示掩碼 */

???????? u_int action;???????????????? /* 表示動作 , 如果是 NIDS_DO_CHKSUM, 表示計算校驗和 ; 如果是 NIDS_DONT_CHKSUM, 表示不計算校驗和 */

???????? u_int reserved;????????????? /* 保留未用 */

};

/*

?* 返回值 :

?* ? : 參數 1 表示 nids_chksum_ctl 列表 參數 2 表示列表中的個數

?* ? : 決定是否計算校驗和 . 它是根據數據結構 nids_chksum_ctl 中的 action 進行決定的 , 如果所要計算的對象不在列表中 , 則必須都要計算校驗和

?*/

extern void nids_register_chksum_ctl(struct nids_chksum_ctl *, int);

?

#endif /* _NIDS_NIDS_H */

posted on 2006-09-29 12:31 JeromeWen 閱讀(3409) 評論(4)  編輯 收藏 引用 所屬分類: C++

評論

# re: Nids.h詳細注釋   回復  更多評論   

不錯,存下先。謝了~~
2006-10-05 16:04 | Jerin

# re: Nids.h詳細注釋   回復  更多評論   

下載lib源碼后編譯會有dll,lib文件生成
2007-03-07 02:33 | JeromeWen

# re: Nids.h詳細注釋 [未登錄]  回復  更多評論   

好! 不錯!
2008-01-06 12:36 | 我的家

# re: Nids.h詳細注釋   回復  更多評論   

不錯啊!
2011-12-16 16:46 | 等等
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            黄色一区三区| 欧美片第一页| 91久久国产综合久久91精品网站| 亚洲一区二区三区精品在线观看| 久久精品人人做人人爽| 久久久久国产精品厨房| 欧美一区2区三区4区公司二百| 在线亚洲欧美| 亚洲欧美日本视频在线观看| 午夜精品一区二区三区在线播放| 欧美亚洲一区在线| 久久免费精品视频| 亚洲黄色成人| 亚洲午夜一级| 久久精品人人爽| 欧美精品国产一区二区| 国产精品女同互慰在线看| 国产欧美日韩综合一区在线播放| 狠狠色丁香久久婷婷综合丁香| 亚洲国产精品嫩草影院| 亚洲视频欧洲视频| 久久久av毛片精品| 亚洲高清不卡在线观看| 亚洲午夜久久久久久久久电影网| 欧美在线黄色| 欧美久久电影| 一区在线电影| 亚洲欧美福利一区二区| 欧美电影免费观看高清完整版| 99精品热视频只有精品10| 久久国产精品久久精品国产| 欧美日韩国产一区二区三区| 在线播放日韩专区| 欧美一区二区三区在线免费观看| 亚洲国产精品久久| 久久国产免费看| 国产精品二区影院| 亚洲国产精品专区久久| 久久黄金**| 亚洲午夜影视影院在线观看| 欧美国产日韩xxxxx| 黄色免费成人| 久久成人久久爱| 亚洲视频福利| 欧美乱妇高清无乱码| 亚洲电影第1页| 久久久久久久一区二区三区| 亚洲图片欧洲图片日韩av| 欧美成人免费网站| 亚洲二区三区四区| 欧美在线一级va免费观看| 日韩午夜一区| 欧美精品一区二区三| 在线播放中文字幕一区| 久久久久一区二区三区| 亚洲欧美激情视频| 国产精品一区二区三区四区| 亚洲一区久久| 亚洲午夜av电影| 国产精品久久久久天堂| 午夜精品www| 亚洲欧美区自拍先锋| 欧美精品国产| 欧美日韩国产精品专区 | 美女久久一区| 久久国产高清| 在线日韩日本国产亚洲| 免费中文日韩| 免费在线看一区| 亚洲黄色成人网| 亚洲国产精品va在线看黑人 | 欧美激情综合五月色丁香| 亚洲精品视频在线| 久久久久国产精品人| 一区视频在线播放| 美女精品一区| 欧美精品不卡| 在线一区欧美| 亚洲欧美经典视频| 国产亚洲欧美一区二区三区| 久久久久久噜噜噜久久久精品| 欧美一进一出视频| 精久久久久久| 欧美激情视频一区二区三区在线播放| 美日韩丰满少妇在线观看| 亚洲三级免费电影| 一区二区电影免费观看| 欧美婷婷久久| 久久久999成人| 欧美精品免费视频| 午夜精品久久久久久久| 欧美在线关看| 亚洲精品少妇网址| 亚洲欧美日韩在线播放| 激情久久五月天| 日韩视频在线一区二区| 国产视频亚洲精品| 亚洲电影视频在线| 国产欧美精品一区二区三区介绍| 欧美成人r级一区二区三区| 欧美日韩亚洲另类| 久久亚洲国产成人| 欧美午夜视频在线| 欧美成人精品| 国产精品豆花视频| 亚洲大胆人体视频| 久久久亚洲国产美女国产盗摄| 久久久久久综合网天天| 亚洲一级在线| 另类图片国产| 欧美在线视频不卡| 欧美日韩成人综合天天影院| 久久婷婷亚洲| 国产精品人人做人人爽人人添| 欧美激情麻豆| 精品99视频| 午夜欧美电影在线观看| 一本久道久久久| 免费不卡在线视频| 正在播放欧美视频| 黑人巨大精品欧美黑白配亚洲 | 国产精品一区久久久| 欧美激情在线有限公司| 国产有码在线一区二区视频| 99热在这里有精品免费| 亚洲狠狠丁香婷婷综合久久久| 欧美亚洲系列| 欧美一区二区啪啪| 国产精品久久久久久久久久久久久久| 欧美激情在线有限公司| ●精品国产综合乱码久久久久 | 欧美日本在线视频| 欧美成人一区二区三区| 一区免费观看| 久久综合狠狠综合久久激情| 久久久一二三| 国产中文一区二区| 欧美一区二区精品在线| 久久aⅴ乱码一区二区三区| 国产精品看片你懂得| 亚洲网在线观看| 性欧美xxxx大乳国产app| 国产精品久久久久天堂| 亚洲免费婷婷| 久久色在线播放| 亚洲国产成人av| 葵司免费一区二区三区四区五区| 久久综合国产精品| 亚洲成色www久久网站| 噜噜噜久久亚洲精品国产品小说| 免费欧美高清视频| 亚洲国产欧美一区二区三区久久 | 久久免费视频一区| 欧美国产日韩xxxxx| 亚洲精品视频免费在线观看| 欧美国产亚洲精品久久久8v| 亚洲国产专区校园欧美| 亚洲一区二区三区四区中文| 国产精品午夜在线| 久久精品日产第一区二区| 免费久久99精品国产自| 99国产精品99久久久久久| 欧美午夜精品理论片a级按摩| 亚洲一区二三| 美女露胸一区二区三区| 日韩视频第一页| 国产精品一区免费在线观看| 久久精品国产2020观看福利| 亚洲第一级黄色片| 亚洲一区综合| 狠狠色狠狠色综合| 欧美人与性禽动交情品| 亚洲在线一区| 亚洲丶国产丶欧美一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美专区亚洲专区| 最近中文字幕mv在线一区二区三区四区 | 国产一本一道久久香蕉| 久久蜜桃精品| 欧美国产在线电影| 久久精品国产99国产精品| 欧美国产高潮xxxx1819| 亚洲一区欧美| 黑丝一区二区| 欧美日韩精品不卡| 欧美中文在线观看| 99精品热6080yy久久| 欧美国产免费| 欧美在线在线| 亚洲午夜精品久久| 亚洲激情专区| 国产亚洲综合精品| 欧美视频在线观看| 欧美mv日韩mv亚洲| 欧美在线观看视频一区二区| 99在线|亚洲一区二区| 欧美福利一区二区| 久久久99精品免费观看不卡| 在线一区二区三区四区五区| 亚洲高清激情|