




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
利用libnids構(gòu)建入侵檢測(cè)系統(tǒng)(1)四川大學(xué)軟件學(xué)院2009-09助教姓名 QQ號(hào) 郵箱羅云 814314989 cloudluo99@王亮 354185558 legend115599@王正霞 593910963 xiaxia_588@126.com李雯 908441949win_lee19860830@3主要內(nèi)容講解Libnids的數(shù)據(jù)結(jié)構(gòu)函數(shù),并給出一些具體的例子,同學(xué)們?cè)诖嘶A(chǔ)上實(shí)現(xiàn)一個(gè)簡(jiǎn)單的協(xié)議分析程序或是一個(gè)簡(jiǎn)單的入侵檢測(cè)系統(tǒng)4什么是libnidsLibnids是一個(gè)基于網(wǎng)絡(luò)入侵檢測(cè)開發(fā)的專業(yè)編程接口。我們利用Libnids可以實(shí)現(xiàn):網(wǎng)絡(luò)數(shù)據(jù)包的捕獲;IP碎片重組、TCP流數(shù)據(jù)重組;入侵檢測(cè)。5Libnids的安裝
安裝Libnids必須要有Libpcap、Libnet庫的支持,所以要想是試用Libnids必須按照Libpcap、Libnet與Libnids的順序安裝這三個(gè)軟件包
安裝方法:
1)下載源碼包;2)釋放歸檔文件;
3)./configure;make;makeinstall6Libnids編程模型#include“nids.h”main(){applicationprivateprocessing,notrelatedtolibnidsoptionalmodificationoflibnidsparametersif(!nids_init())something'swrong,terminate;registrationofcallbackfunctionsnids_run();
//notreachedinnormalsituation}7Libnids基本數(shù)據(jù)結(jié)構(gòu)(1)TCP連接參數(shù)structtuple4{/*源端口和目的端口*/
unsignedshortsource,dest;/*源地址與目的地址*/
unsignedlongsaddr,daddr;};8Libnids基本數(shù)據(jù)結(jié)構(gòu)(2)TCP連接單端信息
structhalf_stream{
用23個(gè)變量了描述TCP連接信息…….};9Libnids基本數(shù)據(jù)結(jié)構(gòu)(3)Charstate;表示套接字的狀態(tài),如TCP_CLOSE、TCP_ESTABLISHED;charcollect;用來指示本端是否接收數(shù)據(jù),>0,將數(shù)據(jù)存放在data指向的字符緩沖區(qū),<0,忽略進(jìn)入本端的數(shù)據(jù);
charcollect_urg;用于指示本端是否接受緊急數(shù)據(jù);
char*data;字符緩沖區(qū),用于存放流向本端的數(shù)據(jù)
intcount;用于指示連接建立后本端已經(jīng)接受的字節(jié)數(shù);10Libnids基本數(shù)據(jù)結(jié)構(gòu)(4)intoffset:表示存儲(chǔ)在data中數(shù)據(jù)的第一個(gè)字節(jié)的偏移量;intcount_new;用于指示是否有新數(shù)據(jù)到達(dá)本端,為0表示沒有新數(shù)據(jù) charcount_new_urg;用于指示是否有新的緊急數(shù)據(jù)到達(dá)本端,為0表示沒有新的數(shù)據(jù)
11Libnids基本數(shù)據(jù)結(jié)構(gòu)(5)TCP連接完整信息structtcp_stream{ structtuple4addr; charnids_state; structhalf_streamclient,server;
……};12Libnids基本數(shù)據(jù)結(jié)構(gòu)(6)addr:用于表示一個(gè)TCP連接的四個(gè)重要信息;nids_state:表示連接的邏輯狀態(tài),共有六種狀態(tài): NIDS_JUST_EST NIDS_CLOSE NIDS_RESET NIDS_TIMED_OUT NIDS_EXITINGNIDS_DATA
13Libnids基本數(shù)據(jù)結(jié)構(gòu)(6)成員client表示客戶端信息,成員server表示客戶端信息。14Libnids庫中常用函數(shù)(1)intnids_init(void)
函數(shù)成功返回1,失敗返回0
函數(shù)功能:對(duì)libnids進(jìn)行初始化,包括打開網(wǎng)絡(luò)接口,打開文件,編譯過濾規(guī)則、設(shè)置過濾規(guī)則、判斷網(wǎng)絡(luò)鏈路層信息15Libnids庫中常用函數(shù)(2)Voidnids_run(void);
此函數(shù)的功能是運(yùn)行l(wèi)ibnids,進(jìn)入循環(huán)捕獲數(shù)據(jù)包的狀態(tài),并將捕獲的數(shù)據(jù)包交給注冊(cè)的回調(diào)函數(shù)進(jìn)行處理16Libnids庫中常用函數(shù)(3)注冊(cè)函數(shù):針對(duì)IP、TCP、UDP協(xié)議分為三類注冊(cè)函數(shù)IP注冊(cè)函數(shù)
voidnids_register_ip(void(*))
注冊(cè)一個(gè)可以處理IP數(shù)據(jù)包的函數(shù),該函數(shù)的定義類型如下:
voidip_function(structip*a_packet)其中a_packet表示的是所捕獲的IP數(shù)據(jù)包17Libnids庫中常用函數(shù)(4)TCP注冊(cè)函數(shù)
voidnids_register_tcp(void(*))
回調(diào)函數(shù)的形式為:
voidtcp_callback(structtcp_stream*ns,void**param)
其中ns表示一個(gè)TCP全連接的所有信息,param表示要傳遞的參數(shù),18Libnids庫中常用函數(shù)(5)UDP注冊(cè)函數(shù)
voidnids_register_udp(void(*));
回調(diào)函數(shù)的形式是
voidudp_callback(structtuple4*addr,char*buf,intlen,structip*iph);addr用于表示接收與發(fā)送端的IP地址與端口,buf表示UDP協(xié)議負(fù)載數(shù)據(jù)的內(nèi)容,參數(shù)len表示UDP負(fù)載數(shù)據(jù)的長(zhǎng)度,IPH表示一個(gè)IP數(shù)據(jù)包,包括IP首部,UDP首部以及UDP負(fù)載19Libnids庫中常用函數(shù)(6)Voidnids_killtcp(structtcp_stream*a_tcp)函數(shù)功能:終止TCP連接Voidnids_discard(structtcp_stream*a_tcp,intnum)函數(shù)的功能是丟棄num字節(jié)的TCP數(shù)據(jù),用于存儲(chǔ)更多的數(shù)據(jù)20試驗(yàn)閱讀與理解libnids給出的例子程序sniff和
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 合作免責(zé)合同范本
- 賣身契約合同范本
- 原料運(yùn)輸合同范本
- 醫(yī)療器械押金合同范本
- 高壓下銅氧化物的超導(dǎo)轉(zhuǎn)變溫度與量子相變研究
- 出售定制廠房合同范本
- 合作簽合同范本
- 臨時(shí)圍擋施工合同范本
- 運(yùn)輸信息服務(wù)合同范本
- 低壓電工測(cè)試題+答案
- 《AutoCAD 中文版實(shí)例教程(AutoCAD 2020) (微課版)(第 2 版)》課件 馬連志 第3、4章 基本繪圖操作、高級(jí)繪圖操作
- 產(chǎn)品國(guó)產(chǎn)化證明書
- 詢價(jià)投標(biāo)文件(范本)
- 幼兒教師職業(yè)道德(高職學(xué)前教育專業(yè))全套教學(xué)課件
- 蘇科版八年級(jí)生物下冊(cè)全冊(cè)完整課件
- 第四單元復(fù)習(xí)教學(xué)設(shè)計(jì) 部編版語文七年級(jí)上冊(cè)
- 醫(yī)學(xué)專家談靈芝孢子粉課件
- 開心麻花《白蛇前傳》劇本
- 全部編版三年級(jí)語文下冊(cè)生字讀音、音序、偏旁及組詞
- 六年級(jí)下冊(cè)英語全冊(cè)教案(冀教版)
- 血小板血漿(PRP)課件
評(píng)論
0/150
提交評(píng)論