計(jì)算機(jī)相關(guān)專業(yè)實(shí)習(xí)報(bào)告_第1頁
計(jì)算機(jī)相關(guān)專業(yè)實(shí)習(xí)報(bào)告_第2頁
計(jì)算機(jī)相關(guān)專業(yè)實(shí)習(xí)報(bào)告_第3頁
已閱讀5頁,還剩5頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、計(jì)算機(jī)相關(guān)專業(yè)實(shí)習(xí)報(bào)告 專業(yè)實(shí)習(xí)報(bào)告871279 朱育民一、工作內(nèi)容這學(xué)期跟李錫捷老師實(shí)習(xí),參加的工作項(xiàng)目是信息安全組,因?yàn)槠綍r(shí)較其它三位組員多接觸unix-like的環(huán)境,因此成為本組組長并協(xié)助聯(lián)絡(luò)事情。我們期初一開始便有正式的case接手,是一個(gè)韓國的駭客教育機(jī)構(gòu)hackerslab委托翻譯他們的一份駭客教材。對(duì)于這方面,我們四人雖然很有愛好,但是相關(guān)的技術(shù)背景都還嫌不夠,因此做起來并不是很輕松,最常碰到的問題就是專業(yè)名詞的查詢與翻譯,常常會(huì)有不知如何是好的窘境發(fā)生,幸好系上的學(xué)長大多能提供我們一些查詢的方向,大部分的問題到最后還是能順利完成,這樣初期的翻譯工作大約持續(xù)了一個(gè)多月后暫時(shí)結(jié)束

2、。對(duì)外的case完成后,我們繼續(xù)朝著信息安全相關(guān)的方向研究,主要是針對(duì)兩個(gè)程序進(jìn)行改進(jìn)工作,一個(gè)為測(cè)試系統(tǒng)漏洞的nessus,一個(gè)為偵測(cè)入侵系統(tǒng)snort,至此小組里再以兩人一組細(xì)分為nessus組跟snort組,各自進(jìn)行測(cè)試工作。我所分配的是nessus組,這是一種可以用來測(cè)試服務(wù)器有哪些網(wǎng)絡(luò)漏洞的程序,由于采用plug-ins的方式安裝,因此可以隨時(shí)安插新漏洞的測(cè)試plug-ins,加上nessus總部的cvs機(jī)制,只要你的nessus系統(tǒng)有定期cvs更新,就能保持最新的完整漏洞測(cè)試。在業(yè)界雜志的評(píng)選里nessus的評(píng)價(jià)甚至超越許多商用軟件(nessus是免費(fèi)的),但是他有個(gè)小缺點(diǎn),就是有

3、關(guān)漏洞測(cè)試報(bào)告的部分作的并不是十分完整,每支漏洞的測(cè)試回報(bào)完整與否,取決于plug-ins作者是否有在寫作plug-ins加上完整的敘述與解決方案,問題是大部分的plug-ins都只有程序代碼,并沒有對(duì)敘述及解決方式作批注說明,因此即使在使用nessus測(cè)出系統(tǒng)的安全漏洞后,使用者必須在到網(wǎng)絡(luò)上搜尋解決方法,這樣作實(shí)在不是很便利,因此老師希望我們能對(duì)于nessus的測(cè)試回報(bào)部分作改良,寫出一個(gè)報(bào)告閱讀程序,結(jié)合龐大的信息安全信息,讓使用者能在檢測(cè)出漏洞的同時(shí),直接取得相關(guān)的信息和解決方案,便利系統(tǒng)治理者在改善本身系統(tǒng)安全的時(shí)效性。二、學(xué)習(xí)1.free hackers zone這學(xué)期最早接觸的學(xué)

4、習(xí)環(huán)境,應(yīng)該要算hackerslab提供的一個(gè)駭客練習(xí)用工作站free hacker zone。這是一臺(tái)用linux架起來的工作站,里面分將使用者分作level0到level14,每取得下依個(gè)等級(jí)的使用者權(quán)限,都有一個(gè)相對(duì)應(yīng)的系統(tǒng)漏洞需要去破解,練習(xí)使用者在實(shí)作中了解駭客破解系統(tǒng)的方法,我一面翻該組織的faq,一面嘗試錯(cuò)誤,讓我一路攻到level10,其中學(xué)習(xí)到的手法包括了使用者權(quán)限設(shè)定,尋找特定權(quán)限的檔案,利用系統(tǒng)分隔符來欺騙系統(tǒng),溢位攻擊等等,然而在前進(jìn)level11時(shí),因?yàn)樵撀┒幢仨氉皂n國本地進(jìn)行破解,因此只好作罷,沒能進(jìn)一步繼續(xù)。不過這個(gè)經(jīng)驗(yàn)對(duì)于后來翻譯hackerslab的文件有的不

5、少的助益!2.hackerslab教材翻譯經(jīng)過這段暖身后,我們正式接下hackerslab文件翻譯的工作,我負(fù)責(zé)的是sniff(監(jiān)聽)與網(wǎng)頁安全兩份教材。在以太網(wǎng)絡(luò)上,只要是同一個(gè)lan上的機(jī)器,都能收到在lan上傳送的封包,系統(tǒng)核心會(huì)進(jìn)行比對(duì),假如該封包是屬于自己的就繼續(xù)處理,假如不是就忽略掉,而sniffing原理就是改變最后的步驟,將所有經(jīng)過的封包,不管是否屬于自己,全部抓進(jìn)來記錄。sniffing的正面意義應(yīng)該是用于處理觀察網(wǎng)絡(luò)流量狀況,一旦網(wǎng)絡(luò)出現(xiàn)異常時(shí),可以藉由sniffing來觀察有哪些異常封包,幫忙排除異常狀況。至于竊取傳送中的使用者賬號(hào)跟密碼,則是cracker的行為,這并非

6、sniffing的本意。對(duì)于區(qū)網(wǎng)內(nèi)要如何避開被sniff,最簡(jiǎn)單是在該區(qū)網(wǎng)內(nèi)使用switch hub。跟hub不同的是,hub會(huì)將接收到的封包向所有連接的host傳送出去,但switch本身具有mac路由表的功能,可以記得哪一個(gè)mac地址要從哪一個(gè)連接埠送出去,因此不會(huì)讓不相關(guān)的host收到該封包,大大減少了被sniff擷取封包的機(jī)會(huì)。另外一種作法是對(duì)于傳送的封包均作加密處理,這樣就算被他人擷取到封包,對(duì)方也很難將封包解密而還原成原本的樣字加以解讀。常見的加密方式例如: ssl(secure socket layer)、pgp (pretty good privacy)、ssh (secure

7、 shell)、vpn (virtual private network)等等。sniff完最重要的工作是分析抓到的封包,因此這里對(duì)于各種通訊協(xié)議的封包意義大致講解過一遍,例如該封包的來源與目的地,長度,數(shù)據(jù)內(nèi)容,crc檢查碼等等。另外一個(gè)章節(jié)是有關(guān)網(wǎng)頁安全,包含了瀏覽器跟服務(wù)器兩部分,這里大多是講解并描述理論性質(zhì)的部分。首先是有關(guān)網(wǎng)頁服務(wù)器,對(duì)于crack的問題,最重要的還是治理者(administrator)的認(rèn)知問題,只要對(duì)系統(tǒng)的安全性隨時(shí)保持警覺,絕對(duì)能防止crack事件的發(fā)生。目前有關(guān)網(wǎng)絡(luò)上的服務(wù)應(yīng)用雖然對(duì)于ftp或e-mail,都有許多獨(dú)立的應(yīng)用程序可以利用(如cute-ftp或o

8、utlook),但現(xiàn)在一般上網(wǎng)的使用者,仍有許多的機(jī)會(huì)直接使用網(wǎng)頁來對(duì)ftp做存取跟收發(fā)e-mail,此外還有許許多多功能,也都被整合在網(wǎng)頁瀏覽中,當(dāng)網(wǎng)頁服務(wù)器要兼任的服務(wù)越多,也就提供了更多讓cracker入侵的機(jī)會(huì),這是進(jìn)展網(wǎng)頁功能的同時(shí)必須付出的代價(jià),因此,身為一個(gè)網(wǎng)頁服務(wù)器的治理員,有責(zé)任負(fù)起保護(hù)自己服務(wù)器使用者的權(quán)益,對(duì)于安全性一定要隨時(shí)保持高度的警覺性。尤其隨著電子商務(wù)的進(jìn)展,網(wǎng)頁扮演的角色越來越吃重,在往夜間傳遞使用者信息的機(jī)會(huì)越來越多,更增加了安全性的顧慮,然而使用者多半對(duì)于這方面安全性問題不夠警覺(甚至不了解嚴(yán)重性),只要有cracker使用一些惡意或欺騙的applet或sc

9、ripts,就有可能將使用者的信息竊取到手,也可以自遠(yuǎn)程將使用者的計(jì)算機(jī)加以控制甚至令其當(dāng)機(jī),使用者對(duì)于瀏覽網(wǎng)頁時(shí)的安全比必須要比過去更加留意。常見的網(wǎng)頁攻擊模式包括:溢位攻擊(buffer overflow) :顧名思義, 就是利用 buffer overflow 的原理達(dá)成目的的.比如, 一個(gè)數(shù)組只有 100 bytes, 但我喂給它 200 bytes 的數(shù)據(jù),于是這個(gè)數(shù)組裝不下這些數(shù)據(jù), 造成了 overflow.為什么 overflow 會(huì)有 security hole 呢?首先, overflow 發(fā)生時(shí), 多出來的數(shù)據(jù)會(huì)蓋到其它變量上,相信這一點(diǎn)大家早就知道了。問題是, 為什么數(shù)

10、據(jù)蓋到其它變量上時(shí), 頂多使程序執(zhí)行錯(cuò)誤,會(huì)嚴(yán)重到出現(xiàn) security 的問題嗎? 這時(shí), 好玩的事情就發(fā)生了.當(dāng)我們呼叫一個(gè) function 時(shí), 以匯編語言的觀點(diǎn),會(huì)將 return address 堆入 stack 中。假如這個(gè) function 宣告了一些 local 變量,那進(jìn)入這個(gè) function 之后, 會(huì)在 stack 中再空出一塊區(qū)域給這些 local 變量,當(dāng)要從這個(gè) function return 回去時(shí), 就把這些在 stack 中的 local 變數(shù)清掉?,F(xiàn)在好了, buffer overflow security hole 就是在這里發(fā)生了.假如有某個(gè) fun

11、ction 宣告了一個(gè) local array, 如:int func() int i, j, k; char buf16; struct abc *x, *y, *z; . . .這樣就很明顯了, 假如在這個(gè) function 內(nèi)有了 bug, 忘記去控制數(shù)據(jù)喂給 buf 的長度,當(dāng)數(shù)據(jù)喂長一點(diǎn), 就可以蓋到這個(gè)function 的 return address指到自己所喂進(jìn)去的 code 上 這時(shí), function 執(zhí)行完畢, 要 return 時(shí), 它就不會(huì) return 到原來呼叫它的地方, 而會(huì) “return” 到我所喂進(jìn)去的那些 code,這么一來入侵者就可以為所欲為了!den

12、ial of service ( dos ,阻斷服務(wù)攻擊) :所謂阻斷服務(wù)攻擊,是攻擊者利用受害者的操作系統(tǒng)、網(wǎng)絡(luò)應(yīng)用程序(服務(wù))或網(wǎng)絡(luò)通訊協(xié)議的漏洞來攻擊受害者,促使目標(biāo)主機(jī)的系統(tǒng)或服務(wù)發(fā)生癱瘓的情況,可能造成系統(tǒng)資源耗盡、引響正常聯(lián)機(jī)品質(zhì)、網(wǎng)絡(luò)頻寬被占滿、網(wǎng)絡(luò)應(yīng)用程序(服務(wù))停止運(yùn)作、系統(tǒng)當(dāng)機(jī)等情形,使正當(dāng)?shù)氖褂谜邿o法正常使用該主機(jī)所提供的服務(wù)。另一種情況是系統(tǒng)治理者為了測(cè)試目的嘗試對(duì)自己主機(jī)展開攻擊,測(cè)試操作系統(tǒng)或是網(wǎng)絡(luò)應(yīng)用程序(服務(wù))中是否含有可能被攻擊的漏洞存在。像立駭科技(hackerslab)的入侵測(cè)試(penetration test)、衛(wèi)道科技的網(wǎng)絡(luò)安全漏空掃瞄儀(nai c

13、ybercop scanner)都可針對(duì)企業(yè)內(nèi)的操作系統(tǒng)、網(wǎng)絡(luò)甚至數(shù)據(jù)庫做健康檢查,其它dos的攻擊都是不合法的,而且動(dòng)機(jī)通常出自惡意。distributed denial of service(ddos,分布式阻斷服務(wù)攻擊):所謂分布式阻斷服務(wù)攻擊,是運(yùn)用在于受害者的系統(tǒng)資源、網(wǎng)絡(luò)頻寬條件都比攻擊者來的好,假如攻擊者想一對(duì)一的攻擊被害者,可能會(huì)失敗甚至導(dǎo)致自己的系統(tǒng)或網(wǎng)絡(luò)癱瘓,所以采取一對(duì)多的攻擊方式,攻擊者先在一些防備較弱的主機(jī)中種植攻擊程序。隨后攻擊者對(duì)各主機(jī)中的的攻擊程序發(fā)出攻擊命令,要求對(duì)目標(biāo)主機(jī)發(fā)出龐大數(shù)量且多種的封包,龐大的數(shù)據(jù)量會(huì)癱瘓目標(biāo)主機(jī)而使得無法正常提供服務(wù)。ddos不但

14、可以提高成功率,還可以縮短攻擊的時(shí)間及減少被發(fā)現(xiàn)的機(jī)會(huì)。以目前駭客的行徑而言,大多比較傾向于使用威力強(qiáng)大的ddos攻擊,尤其是針對(duì)規(guī)模大的網(wǎng)站時(shí)。 cgi :一種讓網(wǎng)頁執(zhí)行外部程序的一種接口,正因?yàn)槿绱?,只要?quán)限或設(shè)定有問題,或程序編寫有問題,很輕易成為cracker入侵系統(tǒng)的快捷方式。自動(dòng)目錄列表 : 取得網(wǎng)頁跟目錄下的檔案列表將使得cracker清楚知道該網(wǎng)站結(jié)構(gòu),很輕易便能發(fā)覺后門所在甚至下載有問題的程序代碼回去破解分析,對(duì)于入侵更為輕易使用者認(rèn)證的攻擊 : 利用一賬號(hào)文件跟密碼字典文件的配合,強(qiáng)制通過網(wǎng)頁認(rèn)證的一種手法。3. nessusnessus官方網(wǎng)站 : ,目前最新釋出的版本為

15、1.0.8,是一種用來偵測(cè)網(wǎng)絡(luò)服務(wù)器或工作站的網(wǎng)絡(luò)漏洞的工具。這套偵測(cè)系統(tǒng)是client-server的方式運(yùn)作,服務(wù)器端包括了使用者賬號(hào)的治理以及各種漏洞測(cè)試的plug-ins,而client則利用服務(wù)器端所提供的各種plug-ins來測(cè)試工作站或服務(wù)器并產(chǎn)生報(bào)告,報(bào)告的格式包括了html、xml、nsr(nessus本身的存檔格式) 、txt、tex(latex格式)。其plug-ins自有一套語法叫做nasl(nessus attack scripts language),可以自訂對(duì)特定的連接埠進(jìn)行封包測(cè)試,藉以判定是否為漏洞(早期使用c語言來作為plug-ins的語法,但以被淘汰)一、

16、安裝安裝的方式分為server跟client兩部分。首先server必須安裝在unix環(huán)境下,(已試過freebsd : ports安裝 跟linux : rpm安裝)這部分沒有什么問題,裝下去就對(duì)了,接下來必須安裝plug-ins(若是不裝plug-ins,nessus什么也不會(huì)測(cè)),plug-ins可以選擇一個(gè)一個(gè)下載后拷到指定目錄即可,不過正確的作法應(yīng)該是使用cvs的方式來維護(hù)更新plug-ins的版本。cvs系統(tǒng)又分作current跟stable兩種,stable版本但講究穩(wěn)定,許多新釋出的plug-ins并沒有包括在里面,而current雖然有最新的plug-ins,但測(cè)試不見得穩(wěn)定

17、正確,有可能將你的受測(cè)工作站或服務(wù)器損害,因此要使用那個(gè)版本請(qǐng)自行斟酌。安裝方式如下:1. 設(shè)定環(huán)境變量 登入cvs系統(tǒng) 密碼為 “ anon” ,只有第一次登入會(huì)需要密碼,以后會(huì)自動(dòng)記載你系統(tǒng)的某一個(gè)地方$ cvs login3-1. 假如要抓取nessus程序stable版本$ cvs -z3 checkout -rnessus_1_0 nessus-libraries$ cvs -z3 checkout -rnessus_1_0 libnasl$ cvs -z3 checkout -rnessus_1_0 nessus-core$ cvs -z3 checkout -rnessus_1_

18、0 nessus-plugins3-2. 假如要抓取nessus程序current版本$ cvs -z3 checkout nessus-libraries$ cvs -z3 checkout libnasl$ cvs -z3 checkout nessus-core$ cvs -z3 checkout nessus-plugins4. 以后要檢查更新部分時(shí)只要打$ cvs -z3 update -p nessus-libraries$ cvs -z3 update -p libnasl$ cvs -z3 update -p nessus-core$ cvs -z3 update -p nes

19、sus-plugins完成!nessus是一套強(qiáng)大的漏洞測(cè)試工具,但是對(duì)于他產(chǎn)生的報(bào)告不夠完整是它的一大致命傷,目前他所采行的方法是把漏洞報(bào)告及修補(bǔ)漏洞的方法寫死在plug-ins里,但并不是每一個(gè)plug-ins撰寫者都有寫上修補(bǔ)方式這部分的說明,因此我們的目的是寫一個(gè)report reader來讀取nessus所產(chǎn)生的報(bào)告并自動(dòng)補(bǔ)上漏洞相關(guān)的網(wǎng)址(報(bào)告格式為html或xml),補(bǔ)強(qiáng)的方式是連結(jié)cert的搜尋器來產(chǎn)生,目前碰到的問題在于我們要選擇哪一種語法來寫這支report reader的程序(vb除外),也使我們的研究主題由nessus暫時(shí)轉(zhuǎn)到了程序語言的部分,因此nessus暫時(shí)在此打

20、住4.scripts language 截至目前為止,我們嘗試過的語言tcl、perl、python都是屬于scripting languages,他們跟c或java這種system programming languages有很大的差異。sl 會(huì)有一組派得上用場(chǎng)的組件 (component) ,用別的語言寫成。sl 不會(huì)從頭開始,而是結(jié)合已經(jīng)寫好的組件。比方說,tcl 跟 visual basic 可以用來治理使用者接口組件,而 unix shell script 可以把組件當(dāng)作 filter ,來組成一條 生產(chǎn)線 ,制造所要的信息。 sl 可以用來擴(kuò)展已經(jīng)存在組件的功能,而很少用來進(jìn)展復(fù)雜的數(shù)據(jù)結(jié)構(gòu)、算法。這些東西應(yīng)該由組件提供。因此,sl 常被稱為 黏接語言 或者 系統(tǒng)整合語言。為了簡(jiǎn)化組合組件的工作,sl通常沒有型態(tài)。所有東西看起來,用起來都一樣,也可以交換著用。比方說,在tcl 或 vb 中,同一個(gè)變量既能存字符串,又能存整數(shù)。而程序代碼跟數(shù)據(jù)可以互通,因此能夠在線產(chǎn)生新程序。由此可以看到sl 對(duì)于文字?jǐn)?shù)據(jù)的處理蠻擅長的。v像這樣無型態(tài)的語言更輕易結(jié)合組件。因?yàn)樗⒉粚?duì) 東西該如何使用 做任何限制。組件會(huì)怎么用,搞不好連原先的設(shè)計(jì)者都不清楚。換句話說,組件的使

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論