Xây dựng hệ thống Voip trên hệ điều hành Android

Voice over Internet Protocol (VOIP), còn gọi là IP Telephony, đang nhanh chóng trở thành một thuật ngữ thông thuộc và công nghệ này đang đi sâu vào các doanh nghiệp, các tổ chức .VOIP được thiết kế để thay thế mạng lưới và công nghệ TDM bằng một mạng dữ liệu dựa trên giao thức mạng IP .Tiếng nói được số hóa và truyền đi trong các gói tin IP .Trong các doanh nghiệp hiện nay nhất là các công ty mạng Internet và cả wifi đã len lỏi đến mọi phòng ban .Mặt khác nhu cầu liên lạc nội bộ trong doanh nghiệp là rất lớn .Sẽ là rất tuyệt vời nếu có một hệ thống Voip ngay trong công ty ,giúp cho việc liên lạc trở nên dễ dàng hơn mà chi phí gần như bằng không vì tận dụng được hạ tầng mạng IP có sẵn .Vì lí do đó em chọn đề tài

docx65 trang | Chia sẻ: lvbuiluyen | Lượt xem: 3802 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Xây dựng hệ thống Voip trên hệ điều hành Android, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
TRƯỜNG ĐẠI HỌC BÁCH KHOA HÀ NỘI VIỆN CÔNG NGHỆ THÔNG TIN VÀ TRUYỀN THÔNG ──────── * ─────── ĐỒ ÁN TỐT NGHIỆP ĐẠI HỌC NGÀNH CÔNG NGHỆ THÔNG TIN Xây dựng hệ thống Voip trên hệ điều hành Android Sinh viên thực hiện: Nguyễn Khắc Vinh Lớp CNPM-K51 Giáo viên hướng dẫn: ThS Vũ Đức Vượng HÀ NỘI 5-2011 PHIẾU GIAO NHIỆM VỤ ĐỒ ÁN TỐT NGHIỆP 1. Thông tin về sinh viên Họ và tên sinh viên: Nguyễn Khắc Vinh Điện thoại liên lạc 01696890500 Email: nkvinh@gmail.com Lớp: CNPM Hệ đào tạo: Đại học chính quy Đồ án tốt nghiệp được thực hiện tại: Trung tâm phần mềm Viettel Thời gian làm ĐATN: Từ ngày 28 /2 /2011 đến 28/5 /2011 2. Mục đích nội dung của ĐATN Tìm hiểu kiến trúc Voip và hệ điều hành cho di động Android Xây dựng hoàn thiện một hệ thống Voip, demo phía client trên máy Android 3. Các nhiệm vụ cụ thể của ĐATN Tìm hiểu về kiến trúc của Voip Tìm hiểu về hệ điều hành Android Tìm hiểu thư viện hỗ trợ để lập trình Voip Client trên Android Chọn proxy server để xây dựng hệ thống Dùng thư viện và server đã chọn xây dựng một hệ thống Voip Bảo mật cho tài khoản khi đăng kí với server Tìm hiểu và lựa chọn giao thức vượt NAT 4. Lời cam đoan của sinh viên: Tôi – Nguyễn Khắc Vinh - cam kết ĐATN là công trình nghiên cứu của bản thân tôi dưới sự hướng dẫn của thạc sĩ Vũ Đức Vượng Các kết quả nêu trong ĐATN là trung thực, không phải là sao chép toàn văn của bất kỳ công trình nào khác Hà Nội, ngày 25 tháng 05 năm 2011 Tác giả ĐATN Nguyễn Khắc Vinh 5. Xác nhận của giáo viên hướng dẫn về mức độ hoàn thành của ĐATN và cho phép bảo vệ: Hà Nội, ngày tháng năm Giáo viên hướng dẫn Thạc sĩ Vũ Đức Vượng MỤC LỤC KHÁI NIỆM VÀ THUẬT NGỮ Thuật ngữ Định nghĩa Ghi chú VOIP Voice over Internet Protocol Công nghệ cho phép truyền thoại sử dụng giao thức mạng IP VOIP over 3G Voice over Internet Protocol over 3G Công nghệ cho phép truyền thoại sử dụng giao thức mạng IP trên hạ tầng mạng 3G (third-generation) TDM Time Division Multiplexing Ghép kênh phân chia thời gian: Thời gian sử dụng đường truyền được chia làm nhiều khung. Mỗi khung được chia thành nhiều khe thời gian(Ts time slot) mỗi người sử dụng một khe thời gian dành riêng cho mình để phục vụ cho việc truyền tin. IP Internet Protocol Giao thức mạng được sử dụng rộng rãi ngày nay End point Các thiết bị đầu cuối: bao gồm IP phone và SIP phone. SIP Session Initiation Protocol Giao thức khởi tạo session UA/ UAC/ UAS User Agent/ Uer Agent Client/ User Agent Server Nơi gửi và nơi đáp trả các bản tin SIP, thông thường là các thiết bị SIP phone G7xx G711/ G729, … Các codec dùng số hóa âm thanh Proxy server Server trung chuyển các bản tin SIP Redirect server Server trả lời điểm tiếp theo mà thiết bị phải gửi bản tin tới. Registrar server Server đăng ký cho các user agent. Thuật ngữ và định nghĩa DANH MỤC CÁC BẢNG Table 1: Bảng Account 34 Table 2: Bảng CallLogs 35 Table 3: Bảng Messages 36 DANH MỤC CÁC HÌNH Figure 1: Kiến trúc của hệ thống Voip 11 Figure 2: Đăng kí với Sip Server thành công 13 Figure 3: Thiết lập thành công cuộc gọi 16 Figure 4: Cơ chế xác thực username và password 22 Figure 5 : Giải pháp qua NAT cho các tín hiệu SIP 23 Figure 6: Giải pháp truyền các gói tin RTP qua NAT 23 Figure 7: Mô hình hệ thống cần xây dựng 26 Figure 8: Mô hình Use case của ứng dụng Voip Android 31 Figure 9: Biểu đồ tuần tự cho chức năng thêm và xem các account 37 Figure 10: Biểu đồ tuần tự cho chức năng xem và xóa lịch sử cuộc gọi 37 Figure 11 : Biểu đồ tuần tự cho chức năng xem và xóa tin nhắn 37 Figure 12: : Biểu đồ tuần tự cho chức năng gửi tin nhắn và tạo cuộc gọi 38 Figure 13 : Biểu đồ tuần tự cho chức năng xóa và sửa tài khoản 39 Figure 14: Kiến trúc ứng dụng Voip Android 39 Figure 15 Class UAStateReceiver 41 Figure 16 SipService 43 Figure 17 SipNotifications 45 Figure 18 Sơ đồ lớp xử lí Media 47 Figure 19 Class SipMessage 48 Figure 20 Class CallInfo 49 Figure 21 Class IAccount 50 Figure 22 AccountState 51 Figure 23 Sơ đồ lớp cho giao diện thêm account 52 Figure 24 Sơ đồ lớp của Voip Android widget 54 Figure 25 Sơ đồ lớp của giao diện xử lí cuộc gọi trong Voip Android 55 Figure 26 Sơ đồ lớp giao diện chính của Voip Android 56 Figure 27 Sơ đồ lớp giao diện cài đặt của Voip Android 57 Figure 28 Sơ đồ lớp giao diện quản lí tài khoản của Voip Android 58 Figure 29 Sơ đồ lớp giao diện quản lí lịch sử cuộc gọi của Voip Android 59 Figure 30 Sơ đồ lớp chọn tài khoản để gọi hoặc gửi tin của Voip Android 60 Figure 31 Quản lí tài khoản 63 Figure 32 Màn hình cài đặt và gửi tin nhắn 64 Figure 33 Màn hình quản lí cuộc gọi 65 LỜI CẢM ƠN Trước tiên em xin gửi lời cám ơn chân thành sâu sắc tới các thầy cô giáo trong trường Đại học Bách Khoa Hà Nội nói chung và các thầy cô giáo trong viện Công nghệ Thông tin, bộ môn Công nghệ Phần mềm nói riêng đã tận tình giảng dạy, truyền đạt cho em những kiến thức, kinh nghiệm quý báu trong suốt thời gian qua. Đặc biệt, em xin gửi lời cảm ơn đến thầy Vũ Đức Vượng. Thầy đã tận tình giúp đỡ, trực tiếp chỉ bảo, hướng dẫn em trong suốt quá trình làm đồ án tốt nghiệp. Trong thời gian làm việc với thầy, em không ngừng tiếp thu thêm nhiều kiến thức bổ ích mà còn học tập được tinh thần làm việc, thái độ nghiên cứu khoa học nghiêm túc, hiệu quả, đây là những điều rất cần thiết cho em trong quá trình học tập và công tác sau này. Đồng thời em xin chân thành cảm ơn anh Cao Xuân Tuấn, trưởng phòng R&D, Trung tâm phần mềm Viettel và anh Đỗ Đình Thắng trưởng ban công nghệ đã tạo mọi điều kiện về cơ sở vật chất giúp em có một môi trường tốt để thực hiện đề tài đã giúp em hoàn thành đề tài này Hà Nội, ngày 25 tháng 5 năm 2011 Người thực hiện Nguyễn Khắc Vinh MỞ ĐẦU Giới thiệu đề tài Voice over Internet Protocol (VOIP), còn gọi là IP Telephony, đang nhanh chóng trở thành một thuật ngữ thông thuộc và công nghệ này đang đi sâu vào các doanh nghiệp, các tổ chức .VOIP được thiết kế để thay thế mạng lưới và công nghệ TDM bằng một mạng dữ liệu dựa trên giao thức mạng IP .Tiếng nói được số hóa và truyền đi trong các gói tin IP .Trong các doanh nghiệp hiện nay nhất là các công ty mạng Internet và cả wifi đã len lỏi đến mọi phòng ban .Mặt khác nhu cầu liên lạc nội bộ trong doanh nghiệp là rất lớn .Sẽ là rất tuyệt vời nếu có một hệ thống Voip ngay trong công ty ,giúp cho việc liên lạc trở nên dễ dàng hơn mà chi phí gần như bằng không vì tận dụng được hạ tầng mạng IP có sẵn .Vì lí do đó em chọn đề tài Xây dựng hệ thống Voip trên hệ điều hành Android Môi trường thực hiện đồ án tốt nghiệp Địa điểm: Trung tâm phần mềm Viettel, Phòng R&D Thành viên đội thực hiện dự án: Quản trị dự án: Đỗ Đình Thắng Thành viên dự án: Đào Hải Hưng Thành viên dự án: Nguyễn Khắc Vinh Dự án: Nghiên cứu thử nghiệm công nghệ Voip Bố cục của đồ án tốt nghiệp Đồ án tốt nghiệp được chia thành các phần như sau: MỞ ĐẦU Giới thiệu đề tài, môi trường thực hiện đồ án, tóm tắt bố cục của đồ án tốt nghiệp PHẦN 1: Đặt vấn đề và định hướng giải pháp Các nhiệm vụ cần thực hiện trong đề tài Cơ sở lý thuyết và công cụ sử dụng. PHẦN 2: Các kết quả đạt được Phân tích yêu cầu Thiết kế hệ thống Cài đặt Đánh giá ưu, nhược điểm của hệ thống KẾT LUẬN Kết luận chung: tự đánh giá công việc làm được và chưa làm được, định hướng phát triển và hoàn thiện hệ thống trong tương lai. PHẦN I: ĐẶT VẤN ĐỀ VÀ ĐỊNH HƯỚNG GIẢI PHÁP Tổng quan về đề tài Các vấn đề cần giải quyết Tìm hiểu về kiến trúc của Voip Tìm hiểu về hệ điều hành Android Tìm hiểu thư viện hỗ trợ để lập trình Voip Client trên Android Chọn server để xây dựng hệ thống Dùng thư viện và server đã chọn xây dựng một hệ thống Voip cơ bản Bảo mật cho tài khoản khi đăng kí với server Tìm hiểu và lựa chọn giao thức vượt NAT Giới thiệu tóm tắt về cơ sở lý thuyết Giới thiệu về VOIP Trong một mạng VOIP, có 2 giao thức được sử dụng chính .Giao thức đầu tiên là Signaling Protocol (giao thức báo hiệu): dùng trong việc khởi tạo và quản lý các tương tác giữa các user session bao gồm voice, video, instant messaging…. Giao thức thứ hai là speech transmission protocol: giao thức truyền tiếng nói. Cả hai giao thức yêu cầu tất cả các thông tin được truyền tải trong các gói tin IP. Cho tới nay có một vài chuẩn cho signaling protocols, gồm có H.323, SIP .Còn RTP là chuẩn cho speech transmission protocol được sử dụng trong các mạng VOIP .Tín hiệu tiếng nói được số hóa, đóng gói trong các gói tin và được truyền thông qua mạng IP .Ta cần rất nhiều các gói tin mới có thể truyền tải được một âm đơn do một người phát ra .Tín hiệu voice được số hóa bằng các sử dụng một trong các chuẩn G.7xx. Figure 1: Kiến trúc của hệ thống Voip Proxy server là một thiết bị trung gian nhận SIP request từ một client và sau đó chuyển tiếp request cho tới khi tới được sip client cần tới .Proxy server là thành phần quan trọng trong hệ thống VoIP, cho phép các user agent trao đổi thông tin, đăng ký người dùng và quản lý trạng thái user agent .Proxy server KHÔNG thực hiện chuyển mạch điện thoại (telephone switch) .Khi proxy server thiết lập một cuộc gọi (peer-to-peer), server sẽ không tham gia vào quá trình truyền tải tiếng nói .Các gói tin chứa tiếng nói được truyền trực tiếp từ một phone tới một phone khác Ngoài ra còn có Registrar server Xử lý các requests từ các UAC để đăng ký vị trí (ip, port) của UAC đó .Registrar server thường được đặt cùng với proxy server Giới thiệu về SIP SIP là giao thức tầng application trong mô hình OSI nó được sử dụng để thiết lập, thay đổi, và kết thúc các session, SIP là giao thức thuần text (clear text) .Thiết lập các tham số về media được sử dụng (codec, ip, port) giữa các UA thông qua Session Description Protocol (SDP) .Giao thức SIP được thiết kế là một phần của một kiến trúc đa phương tiện bao gồm các giao thức khác như RTP, SDP .Tuy nhiên SIP không phụ thuộc vào các giao thức khác để làm việc .Địa chỉ SIP giống như một địa chỉ email, ví dụ như: johndoe@sipA.com. Các phương thức có trong SIP gồm có: INVITE = Thiết lập phiên ACK = Xác nhận yêu cầu INVITE BYE = Kết thúc phiên CANCEL = Hủy bỏ việc thiết lập phiên REGISTER = Trao đổi thông tin địa điểm người dùng (tên máy, IP) OPTIONS = Trao đổi các thông tin về khả năng của các điện thoại SIP gọi và nghe trong phiên Đáp úng cho các phương thức trên dưới dạng là text như trong HTML, có 6 loại Phản hồi SIP: 1xx = phản hồi thông tin, ví dụ 180, có nghĩa là đang đổ chuông 2xx = phản hồi thành công 3xx = phản hồi chuyển hướng 4xx = yêu cầu bị thất bại 5xx = lỗi máy chủ 6xx = thất bại toàn cục Giới thiệu về RTP Giao thức truyền tín hiệu giọng nói, hình ảnh chuẩn được sử dụng trên mạng Internet hiện nay là giao thức RTP (Real-time transport protocol) .RTP được sử dụng rộng rãi trong các ứng dụng liên lạc và giải trí cần tới streaming dữ liệu Tài liệu đặc tả của RTP mô tả hai giao thức con: Giao thức truyền dữ liệu, RTP, chịu trách nghiệm truyền dữ liệu thời gian thực. Thông tin cung cấp cho giao thức này bao gồm timestamps (để đồng bộ hóa), chuỗi số (cho kiểm tra gói tin bị mất) và tham số chỉ định dạng của dữ liệu. Một giao thức điều khiển, RTCP, dùng để tính toán các tham số trên đường truyền RTP để tối ưu đường truyền. Băng thông của RTCP tương đối nhỏ so với RTP, nằm trong khoảng 5%. Có một vài chuẩn số hóa dữ liệu âm thanh và một trong số chúng được sử dụng chủ yếu trong VoIP .Đa số các nhà cung cấp dịch vụ và thiết bị hỗ trợ một hoặc nhiều các chuẩn đưa ra bởi ITU như dưới đây: G.711 là chuẩn mặc định cho tất cả các nhà cung cấp (dịch vụ và thiết bị), cũng như cho PSTN. Chuẩn này số hóa voice thành dữ liệu không nén có bitrate là 64 Kbps G.729 được hỗ trợ bởi nhiều nhà cung cấp cho phép nén dữ liệu âm ở bitrate 8 Kbps. Chất lượng của chuẩn này kém hơn so với G.711, nó cũng là chuẩn phổ biến thứ 2 sau G.711 G.723.1 là chuẩn nén được khuyến cáo. Bitrate của dữ liệu theo chuẩn này là 6.3 và 5.3 kbps. Mặc dù chuẩn này làm giảm gắng nặng băng thông, nhưng chất lượng thấp hơn đáng kể so với G.729 và không được phổ biến trong VoIP. G.722 có bitrate 64kbps nhưng có độ trung thực về tiếng nói cao. Trái với ba chuẩn trước sử dụng tần số lấy mẫu vào khoảng 3.4 kHz, G.722 lấy mẫu với tần số 7 kHz. Chuẩn này sẽ được sử dụng phổ biến trong tương lai. Trong mọi trường hợp, IP phone lấy dữ liệu số của 10 đến 30 ms và đặt nó trong gói tin RTP và truyền đi Đăng ký, thiết lập cuộc gọi với SIP proxy server Đăng ký mới: Khi User muốn sử dụng IP phone để sử dụng dịch vụ VoIP họ phải thực hiện bước đăng ký địa chỉ sip của họ với một registrar server.Registrar server cung cấp các thông tin về user cho location server (location database) dựa trên các request đã nhận được từ user .SIP phone sử dụng phương thức REGISTER để register tới registrar server. Server nhận và lưu các thông tin trong request nhận được vào location database .Registrar server có thể chấp nhận các loại thông tin khác nhau, không chỉ địa chỉ IP của client .Database có chứa tất cả các ánh xạ giữa địa chỉ SIP tương ứng với địa chỉ IP của client, ví dụ: SIP user 8590@ekiga.net đăng ký ở địa chỉ IP 200.180.1.1. Figure 2: Đăng kí với Sip Server thành công Caller gửi SIP REGISTER request tới SIP server .Request này bao gồm trong nó danh sách liên lạc (contact list) của user đó (danh sách các địa chỉ SIP của Caller). SIP server yêu cầu user nhập thông tin (user ID và password) để xác thực .SIP client mã hóa thông tin người dùng và gửi tới server .Server xác thực thông tin người dùng, nếu thành công nó trả về chuỗi 200 OK cho SIP client .Với cơ chế này client sử dụng giá trị nonce (Do server sinh ra và gửi cho client và là dãy số chỉ dùng 1 lần, tương tự như one time password) để tạo ra thông tin gửi lên server. Thông tin gửi lên server gồm có checksum của username, password, giá trị nonce (username, cnonce, hash (nonce +cnonce + password)) và kết hợp với một số giá trị khác .Theo cách này, password của người dùng được gửi đi không bao giờ tồn tại dưới dạng clear text và cũng không thể giải mã được ra password F1 REGISTER sip: 192.168.133.193 SIP/2.0 Via: SIP/2.0/UDP 192.168.133.193:6060; rport; branch=z9hG4bKBuZ0keykB Max-Forwards: 70 To: From: ;tag=1mzIc5Cd Call-ID: Ne4rmYWF-1295248430029@cn.vinhnk CSeq: 1 REGISTER Contact: sip:1000@192.168.133.193:6060;transport=UDP F2 SIP/2.0 401 Unauthorized Via: SIP/2.0/UDP 192.168.133.193:6060;rport=6060;branch=z9hG4bKBuZ0keykB To: ;tag=b27e1a1d33761e85846fc98f5f3a7e58.436b From: ;tag=1mzIc5Cd Call-ID: Ne4rmYWF-1295248430029@cn.vinhnk CSeq: 1 REGISTER WWW-Authenticate: Digest realm="192.168.133.193", nonce="TTPtWU0z7C2nKObujoCYR89YfUq3YDxC" Server: kamailio (3.1.0 (i386/linux)) Content-Length: 0 Server đòi username và password nó gửi về giá trị nonce="TTPtWU0z7C2nKObujoCYR89YfUq3YDxC" F3 REGISTER sip:192.168.133.193 SIP/2.0 Via: SIP/2.0/UDP 192.168.133.193:6060;rport;branch=z9hG4bK2LKuG1vwn Max-Forwards: 70 To: From: ;tag=bYwlyuoF Call-ID: Ne4rmYWF-1295248430029@cn.vinhnk CSeq: 2 REGISTER Contact: Authorization: Digest username="1000", realm="192.168.133.193", nonce="TTPtWU0z7C2nKObujoCYR89YfUq3YDxC", uri="sip:192.168.133.193", response="ba7b6b7988a263cba8de358cc3eac7e1" Client dùng MD5 tính checksum của password, nonce … rồi gửi response="ba7b6b7988a263cba8de358cc3eac7e1" trở lại server. F4 SIP/2.0 200 OK Via: SIP/2.0/UDP 192.168.133.193:6060;rport=6060;branch=z9hG4bK2LKuG1vwn To: ;tag=b27e1a1d33761e85846fc98f5f3a7e58.8f80 From: ;tag=bYwlyuoF Call-ID: Ne4rmYWF-1295248430029@cn.vinhnk CSeq: 2 REGISTER Contact: ;expires=3600 Server: kamailio (3.1.0 (i386/linux)) Content-Length: 0 Khi user 1000@192.168.133.193 Log out khỏi server 192.168.133.193 nó tạo request: REGISTER sip:192.168.133.193 SIP/2.0 Via: SIP/2.0/UDP 192.168.133.193:6060;rport;branch=z9hG4bKZOmdS4hLG Max-Forwards: 70 To: From: ;tag=FLjcVEm6 Call-ID: Ne4rmYWF-1295248430029@cn.vinhnk CSeq: 4 REGISTER Contact: ;expires=0 Authorization: Digest username="1000", realm="192.168.133.193", nonce="TTPt+k0z7M6EsW/CXuH6wCl9ZHF244HG", uri="sip:192.168.133.193", response="d18e2c819303f864d9b09280015267df" Sau đó server trả về thành công: SIP/2.0 200 OK Via: SIP/2.0/UDP 192.168.133.193:6060;rport=6060;branch=z9hG4bKZOmdS4hLG To: ;tag=b27e1a1d33761e85846fc98f5f3a7e58.d2d1 From: ;tag=FLjcVEm6 Call-ID: Ne4rmYWF-1295248430029@cn.vinhnk CSeq: 4 REGISTER Server: kamailio (3.1.0 (i386/linux)) Content-Length: 0 Thiết lập cuộc gọi Khi user thiết lập một cuộc gọi, một SIP request được gửi tới SIP server (một proxy server hoặc một redirect server) .Trong request này bao gồm địa chỉ của người gọi (trường From) và địa chỉ của người nhận (trường To).Khác với phương thức REGISTER, phương thức INVITE được sử dụng để thiết lập các media session giữa các user agent .Một media session được thiết lập khi các bản tin INVITE ,200 OK, ACK được trao đổi giữa UAC và UAS .Phương thức BYE được sử dụng bởi một trong các UA để kết thúc media session đã được thiết lập. UAC mà khởi tạo một INVITE request sẽ tạo ra một Call-ID duy nhất, sử dụng cho việc xác định thời gian của cuộc gọi. Biến đếm CSeq được khởi tạo (không cần giá trị phải bằng 1, nhưng phải là một số nguyên) và tăng khi có một request mới từ cùng một Call-ID. Trường To và From trong header của request là địa chỉ SIP của người nhận và người gọi. Trường Expires trong header của một INVITE request cho UAS biết request này có hiệu lực trong khoảng thời gian bao lâu .Một khi media session được thiết lập thì trường này sẽ không còn ý nghĩa nữa .Trường Session-Expires có thể được sử dụng để giới hạn thời gian của một session. Figure 3: Thiết lập thành công cuộc gọi Trong phần này sẽ đi chi tiết về việc thiết lập cuộc gọi (thiết lập sesssion) giữa hai SIP UA: 1000@192.168.133.193 (Alice) và 1001@192.168.133.193 (Bob) .Sự trao đổi thông tin về media của UA được đặt trong SDP payloads .Trong phần này, cuộc gọi được thiết lập và cuối cùng yêu cầu kết thúc cuộc gọi đến từ phía 1000. F1 INVITE sip:1001@192.168.133.193 SIP/2.0 Via: SIP/2.0/UDP 192.168.133.193:6060;rport;branch=z9hG4bKrybFW32gj Max-Forwards: 70 To: From: ;tag=mXuZXR5C Call-ID: bdpjEqZN-1295245265337@cn.vinhnk CSeq: 4 INVITE Content-Length: 218 Content-Type: application/sdp Contact: Proxy-Authorization: Digest username="1000", realm="192.168.133.193", nonce="TTPg/E0z39DX2sC/XzRzl8PQlpKPQDlQ", uri="sip:1001@192.168.133.193", response="3e671b21bfe90c3e9c94ec63c229041c" v=0 o=user1 1782520463 2100547947 IN IP4 192.168.133.193 s=- c=IN IP4 192.168.133.193 t=0 0 m=audio 8000 RTP/AVP 0 8 101 a=rtpmap:0 PCMU/8000 a=rtpmap:8 PCMA/8000 a=rtpmap:101 telephone-event/8000 a=sendrecv Nội dung bản tin SDP (từ đoạn v=0) ở request này cho biết. SIP phone của 1000 sẽ nhận RTP audio có loại codec là 0, 8, 101 ở 192.168.133.193: 8000 F2 SIP/2.0 180 Ringing Via: SIP/2.0/UDP 192.168.133.193:6060;rport=6060;branch=z9hG4bKrybFW32gj Record-Route: Contact: To: ;tag=ca470244 From: ;tag=mXuZXR5C Call-ID: bdpjEqZN-1295245265337@cn.vinhnk CSeq: 4 INVITE User-Agent: X-Lite release 1002tx stamp 29712 Content-Length: 0 Chấp nhận cuộc gọi 1001@192.168.133.193 trả lời: F3 SIP/2.0 200 OK Via: SIP/2.0/UDP 192.168.133.193:6060;rport=6060;branch=z9hG4bKrybFW32gj Record-Route: Contact: To: ;tag=ca470244 From: ;tag=mXuZXR5C Call-ID: bdpjEqZN-1295245265337@cn.vinhnk CSeq: 4 INVITE Allow: INVITE, ACK, CANCEL, OPTIONS, BYE, REFER, NOTIFY, MESSAGE, SUBSCRIBE, INFO Content-Type: application/sdp User-Agent: X-Lite release 1002tx stamp 29712 Content-Length: 247 v=0 o=- 6 2 IN IP4 192.168.133.196 s= c=IN IP4 192.168.133.196 t=0 0 m=audio 52062 RTP/AVP 0 8 101 a=fmtp:101 0-15 a=rtpmap:101 telephone-event/8000 a=sendrecv a=x-rtp-session-id: 9BF1CA1AD44A4BBDB2F89BE1533DFFB0 Nội dung bản tin SDP (từ đoạn v=0) ở response trên cho biết. SIP phone của 1001 sẽ nhận RTP audio có loại codec là 0, 8, 101 ở 192.168.133.196: 52062 F4 ACK sip:1001@192.168.133.196:32322;rinstance=2f19f079276fe5f9 SIP/2.0 Via: SIP/2.0/UDP 192.168.133.193:6060;rport;branch=z9hG4bKrybFW32gj To: ;tag=ca47