Luận văn Xây dựng ứng dụng bắt gói tin cho việc phân tích thông tin mạng phục vụ quản lý

Luận văn gồm có 3 phần và 7 chương PHẦN 1: TỔNG QUAN Chương 1: Giới thiệu về đề tài PHẦN 2: TÌM HIỂU CÁC VẤN ĐỀ LẬP TRÌNH. Phần này giới thiệu các vấn đề về lập trình cơ bản nhất để xây dựng 1 ứng dụng có khả năng bắt các gói tin và cho phép người dùng có thể điều khiển từ xa qua môi trường mạng. Chương 2: Tìm hiểu thư viện lập trình mạng cấp thấp libcap, đây là "trái tim" của hầu hết các ứng dụng bắt gói tin mã nguồn mở hiện nay. Chương 3: Giới thiệu MySQL, một hệ quản trị cơ sở dữ liệu tầm trung được sử dụng phổ biến nhất hiện nay. Chương 4: Tìm hiểu kỹ thuật lập trình socket để viết các ứng dụng trên môi trường mạng PHẦN 3: XÂY DỰNG ỨNG DỤNG PACKETCAP. Phần này sẽ sử dụng các kiến thức đã tìm hiểu ở chương 2,3,4 để xây dựng một ứng dụng bắt gói tin, lưu các kết quả bắt được vào cơ sở dữ liệu để phân tích các thông tin mạng. Chương 5: Phân tích, thiết kế ứng dụng PacketCap Chương 6: Cài đặt và thử nghiệm PacketCap Chương 7: Tổng kết. Chương này trình bày những kết quả đạt được, những hạn chế và hướng phát triển PacketCap trong tương lai

pdf91 trang | Chia sẻ: diunt88 | Lượt xem: 2270 | Lượt tải: 2download
Bạn đang xem trước 20 trang tài liệu Luận văn Xây dựng ứng dụng bắt gói tin cho việc phân tích thông tin mạng phục vụ quản lý, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
TRѬӠNG ĈҤI HӐC KHOA HӐC TӴ NHIÊN KHOA CÔNG NGHӊ THÔNG TIN %Ӝ MÔN CÔNG NGHӊ PHҪN MӄM GIANG QUӔC MINH – HӖ PHҤM THÁI VINH XÂY DͰNG ͨNG 'ͤNG BɫT GÓI TIN CHO VIʃC PHÂN TÍCH THÔNG TIN 0ɝNG PHͤC 9ͤ QUɟN LÝ KHOÁ LUҰN CӰ NHÂN TIN HӐC TP. HCM, 1ĂM 2005 TRѬӠNG ĈҤI HӐC KHOA HӐC TӴ NHIÊN KHOA CÔNG NGHӊ THÔNG TIN %Ӝ MÔN CÔNG NGHӊ PHҪN MӄM GIANG QUӔC MINH - 0112016 HӖ PHҤM THÁI VINH - 0112081 XÂY DͰNG ͨNG 'ͤNG BɫT GÓI TIN CHO VIʃC PHÂN TÍCH THÔNG TIN 0ɝNG PHͤC 9ͤ QUɟN LÝ KHÓA LUҰN CӰ NHÂN TIN HӐC GIÁO VIÊN HѬӞNG DҮN GVC CAO ĈĂNG TÂN NIÊN KHÓA 2001 – 2005 NHҰN XÉT &ӪA GIÁO VIÊN HѬӞNG DҮN ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... Tp.HCM, ngày…..tháng….năm 2005 NHҰN XÉT &ӪA GIÁO VIÊN PHҦN BIӊN ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... ........................................................................................................................... Tp.HCM, ngày…..tháng….năm 2005 LӠI CÁM ѪN Chúng em xin chân thành cám ѫn Ban giám hiӋu, quý Thҫy cô Fӫa trѭӡng Ĉҥi Hӑc Khoa Hӑc Tӵ Nhiên TP. Hӗ Chí Minh, ÿһc biӋt là các Thҫy cô trong Khoa Công nghӋ Thông tin ÿã tұn tình giҧng Gҥy, trang Eӏ cho chúng em nhӳng kiӃn thӭc cҫn thiӃt, bә ích trong suӕt nhӳng năm Kӑc tұp Wҥi trѭӡng. Chúng em xin chân thành Fҧm ѫn Thҫy Cao Ĉăng Tân, ngѭӡi Thҫy ÿã tұn tình quan tâm hѭӟng dүn, giúp ÿӥ chúng em trong suӕt thӡi gian làm luұn Yăn này. Chúng con xin gӱi lòng biӃt ѫn sâu sҳc và sӵ kính trӑng ÿӃn ông bà, cha Pҽ, cùng toàn thӇ gia ÿình, nhӳng ngѭӡi ÿã nuôi Gҥy chúng con trѭӣng thành nhѭ ngày hôm nay. Chúng tôi xin chân thành cám ѫn sӵ giúp ÿӥ, ÿӝng viên, nhұn xét, ÿóng góp ý kiӃn cӫa các anh chӏ, Eҥn bè trong quá trình thӵc hiӋn luұn văn này. TP. Hӗ Chí Minh, 7/2005 Nhóm sinh viên thӵc hiӋn Giang Quӕc Minh – Hӗ Phҥm Thái Vinh BӔ CӨC &ӪA LUҰN VĂN Luұn văn gӗm có 3 phҫn và 7 chѭѫng PHҪN 1: TӘNG QUAN Chѭѫng 1 Giӟi thiӋu vӅÿӅ tài PHҪN 2: TÌM HIӆU CÁC VҨN Ĉӄ LҰP TRÌNH. Phҫn này giӟi thiӋu các vҩn ÿӅ lұp trình cѫ Eҧn nhҩt ÿӇ xây dӵng 1ӭng Gөng có khҧ Qăng bҳt các gói tin và cho phép ngѭӡi dùng có thӇ ÿiӅu khiӇn tӯ xa qua môi trѭӡng Pҥng. Chѭѫng 2. Tìm hiӇu thѭ viӋn lұp trình mҥng cҩp thҩp libpcap, ÿây là “trái tim” Fӫa hҫu hӃt các ӭng Gөng bҳt gói tin mã nguӗn mӣ hiӋn nay. Chѭѫngg 3. Giӟi thiӋu MySQL, mӝt hӋ quҧn trӏ Fѫ sӣ dӳ liӋu tҫm trung ÿѭӧc sӱ dөng phә biӃn nhҩt hiӋn nay. Chѭѫng 4. Tìm hiӇu Nӻ thuұt lұp trình socket ÿӇ viӃt các ӭng Gөng trên môi trѭӡng Pҥng Phҫn 3 Xây Gөng ӭng Gөng PacketCap. Phҫn này VӁ sӱ dөng các kiӃn thӭc ÿã tìm hiӇu ӣ chѭѫng 2, 3, 4 ÿӇ xây dӵng mӝt ӭng Gөng bҳt gói tin, Oѭu các kӃt quҧ bҳt ÿѭӧc vào cѫ sӣ dӳ liӋu ÿӇ phân tích các thông tin Pҥng. Chѭѫng 5. Phân tích, thiӃt kӃӭng Gөng PacketCap Chѭѫng 6. Cài ÿһt và thӱ nghiӋm PacketCap Chѭѫng 7. Tәng kӃt. Chѭѫng này trình bày nhӳng kӃt quҧ ÿҥt ÿѭӧc, nhӳng Kҥn chӃ và hѭӟng phát triӇn PacketCap trong tѭѫng lai. Các danhPөc 11 MӨC /ӨC DANH SÁCH HÌNH.................................................................................... 14 DANH SÁCH %ҦNG .................................................................................. 15 PHҪN 1: TӘNG QUAN .............................................................................. 16 Chѭѫng 1: Giӟi thiӋu ÿӅ tài .......................................................................... 17 1.1. Ĉһt vҩn ÿӅ .......................................................................................... 17 1.2. Giӟi thiӋu ÿӅ tài.................................................................................. 18 1.3. Yêu cҫu Fӫa ÿӅ tài .............................................................................. 19 PHҪN 2: TÌM HIӆU CÁC VҨN Ĉӄ LҰP TRÌNH ...................................... 20 Chѭѫng 2 : Thѭ viӋn lұp trình Pҥng libpcap ................................................ 21 2.1. Giӟi thiӋu libpcap............................................................................... 21 2.2. Cài ÿһt thѭ viӋn libpcap ..................................................................... 21 3.3. Các bѭӟc xây dӵng chѭѫng trình sӱ dөng libpcap.............................. 22 3.4. Chi tiӃt các bѭӟc ................................................................................ 23 3.4.1. Chӑn Interface( card Pҥng) ......................................................... 23 3.4.2. Mӣ device ÿӇ lҳng nghe( sniff) dӳ liӋu......................................... 24 3.4.3. /ӑc traffic .................................................................................... 25 Chѭѫng 3: HӋ quҧn trӏ Fѫ sӣ dӳ liӋu MySQL ............................................... 34 3.1. Giӟi thiӋu vӅ MySQL......................................................................... 34 3.2. Cài ÿһt MySQL.................................................................................. 34 3.2.1. Cài Ĉһt MySQL tӯ các gói nhӏ phân ............................................ 34 3.2.2. Cài ÿһt tӯ mã nguӗn..................................................................... 35 3.3. Sӱ dөng MySQL ................................................................................ 36 3.3.1. LӋnh mysql .................................................................................. 36 3.3.2. LӋnh mysqladmin ........................................................................ 36 3.3.3. LӋnh mysqlshow.......................................................................... 36 3.3.4. LӋnh grant.................................................................................... 37 3.3.5. LӋnh Revoke................................................................................ 38 3.3.6. Ví dө vӅ tҥo mӝt cѫ sӣ dӳ liӋu ..................................................... 38 3.4. Lұp trình MySQL trên ngôn ngӳ C .................................................... 38 4.4.1 mysql_init..................................................................................... 38 3.4.2 mysql_real_connection ................................................................. 39 3.4.3 mysql_query ................................................................................. 40 3.4.4. mysql_affected_rows ................................................................... 40 3.4.5. mysql_store_result ....................................................................... 40 3.4.6. mysql_fetch_row ......................................................................... 40 3.4.7. mysql_row_seek .......................................................................... 41 3.4.8. mysql_free_result ........................................................................ 41 Các danhPөc 12 Chѭѫng 4: Lұp trình socket .......................................................................... 42 4.1. Giӟi thiӋu vӅ lұp trình socket ............................................................. 42 4.2. Nguyên lý hoҥt ÿӝng Fӫa socket......................................................... 42 4.3. Lұp trình vӟi socket ........................................................................... 44 4.3.1. Các thuӝc tính Fӫa socket............................................................. 44 4.3.1.1. Vùng( domain) ...................................................................... 44 5.3.1.2. KiӇu socket(type)................................................................... 46 4.3.1.3. Giao thӭc Fӫa socket( protocol) ............................................. 47 4.3.2. 7ҥo socket.................................................................................... 48 4.3.3. Ĉӏnh ÿӏa chӍ cho socket................................................................ 49 4.3.4. Ĉһt tên cho socket........................................................................ 51 4.3.5. 7ҥo hàng ÿӧi cho socket .............................................................. 52 4.3.6. Chӡ và chҩp nhұn kӃt nӕi............................................................. 53 4.3.7. Yêu cҫu kӃt nӕi ............................................................................ 54 4.3.8. Ĉóng kӃt nӕi ................................................................................ 55 4.3.9. Giao tiӃp bҵng socket................................................................... 56 4.4. Sӱ dөng socket trong ӭng Gөng minh Kӑa ....................................... 58 PHҪN 3: XÂY DӴNG ӬNG 'ӨNG THӰ NGHIӊM PACKETCAP ......... 59 Chѭѫng 5: Phân tích và thiӃt kӃ PacketCap .................................................. 60 5.1. Khҧo sát hiӋn trҥng ............................................................................ 60 5.2. Phân tích và xác ÿӏnh yêu cҫu ............................................................ 61 5.2.1. Phân tích ...................................................................................... 61 5.2.2. Xác ÿӏnh yêu cҫu ......................................................................... 61 5.3. Các hѭӟng xây dӵng ӭng Gөng PacketCap......................................... 63 5.3.1. Phân tích hѭӟng phát triӇn dӵa trên Ethereal................................ 63 5.3.2. Phân tích hѭӟng phát triӇn dӵa trên libcap ................................... 64 5.3.3. Lӵa chӑn hѭӟng phát triӇn PacketCap ......................................... 64 5.4. Các thành phҫn PacketCap ................................................................. 65 5.5. Xây dӵng mô hình use case................................................................ 66 5.5.1. Xác ÿӏnh Actor và use case .......................................................... 66 5.5.2. Mô hình use case ......................................................................... 66 5.6. Ĉһt Wҧ use case.................................................................................... 67 5.6.1. Connect........................................................................................ 67 5.6.2. StartCapture................................................................................. 68 5.6.3. StopCapture ................................................................................. 69 5.6.4. GetFilter....................................................................................... 70 5.6.5. Terminate..................................................................................... 71 Các danhPөc 13 5.7.ThiӃt kӃ dӳ liӋu ................................................................................... 72 5.7.1. Phân tích các hѭӟng lѭu trӳ ......................................................... 72 5.7.2. ThiӃt kӃ Fѫ sӣ Gѭ liӋu................................................................... 75 5.7.2.1. Danh sách các ÿәi tѭӧng (table)............................................. 75 5.7.2.2 Table PACKET ...................................................................... 75 6.7.2.4. Table IP ................................................................................. 76 5.7.2.5. Table TCP ............................................................................. 76 5.7.2.6. Table UDP............................................................................. 77 5.7.2.7 Table ICMP ............................................................................ 77 5.7.2.8 Table IGMP............................................................................ 78 5.7.2.9. Table ARP............................................................................. 80 5.8. Xây dӵng PCServer( server), PCManager(client)............................... 81 5.8.1. Lѭu ÿӗ PCServer ......................................................................... 81 5.8.2. Lѭu ÿӗ PCManager( Client)......................................................... 82 5.8.3. Cҩu trúc dӳ liӋu trao ÿәi giӳa PCServer và PCManager............... 83 5.9.ThiӃt kӃ giao diӋn PCManager( phiên Eҧn chҥy trên Windows) .......... 85 Chѭѫng 6: Cài ÿһt và thӱ nghiӋm................................................................. 87 6.1. Cài ÿһt................................................................................................ 87 6.2. Thӱ nghiӋm........................................................................................ 88 6.2.1. Mô hình thӱ nghiӋm 1.................................................................. 88 6.2.2. Mô hình thӱ nghiӋm 2.................................................................. 89 6.2.3. Mô hình thӱ nghiӋm 3.................................................................. 90 Chѭѫng 7: Tәng kӃt ..................................................................................... 91 7.1. KӃt luұn.............................................................................................. 91 7.1.1. KӃt quҧ ÿҥt ÿѭӧc.......................................................................... 91 7.1.2. +ҥn chӃ........................................................................................ 91 7.2. Hѭӟng phát triӇn ................................................................................ 92 PHӨ LӨC Hѭӟng dүn sӱ dөng PacketCap ................................................... 93 1.Chѭѫng trình PCServer.......................................................................... 93 2. Chѭѫng trình PCManager ..................................................................... 93 2.1. PCManager trên môi trѭӡng Linux ................................................. 93 2.2. PCManager trên môi trѭӡng Windows............................................ 94 TÀI LIӊU THAM KHҦO............................................................................ 95 Các danhPөc 14 DANH SÁCH HÌNH Hình 5-1 Các thành phҫn Fӫa PacketCap.................................................
Tài liệu liên quan