Python程序設計教程 課件 第12章-網絡編程_第1頁
Python程序設計教程 課件 第12章-網絡編程_第2頁
Python程序設計教程 課件 第12章-網絡編程_第3頁
Python程序設計教程 課件 第12章-網絡編程_第4頁
Python程序設計教程 課件 第12章-網絡編程_第5頁
已閱讀5頁,還剩23頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第12章-網絡編程馬馳率風,羊致清和本章目標了解網絡編程的基本概念了解七層協(xié)議與四層協(xié)議掌握TCP/IP協(xié)議掌握UDP協(xié)議掌握Socket套接字熟練應用TCP編程熟練應用UDP編程馬馳率風,羊致清和網絡編程與通信協(xié)議什么是通信協(xié)議?協(xié)議即規(guī)則,就好比汽車上路要遵守交通規(guī)則一樣,為了使全世界不同類型的計算機都可以連接起來,所以制定了一套全球通用的通信協(xié)議—Internet協(xié)議。有了Internet協(xié)議,任何私有網絡,只要支持這個協(xié)議,就可以接入互聯網。馬馳率風,羊致清和網絡編程與通信協(xié)議馬馳率風,羊致清和TCP/IP協(xié)議IPIP協(xié)議是整個TCP/IP協(xié)議族的核心IP地址就是互聯網上計算機的唯一標識目前的IP地址有兩種表示方式,即IPv4和IPv6在命令行下使用ipconfig命令可以查看本機的IP地址馬馳率風,羊致清和TCP/IP協(xié)議TCPTCP(TransmissionControlProtocol)協(xié)議即傳輸控制協(xié)議,是建立在IP協(xié)議基礎之上的。TCP協(xié)議負責兩臺計算機之間建立可靠連接,保證數據包按順序發(fā)送到。它是一種可靠的、一對一的、面向有連接的通信協(xié)議。馬馳率風,羊致清和TCP/IP協(xié)議TCP/IP協(xié)議中的四個層次馬馳率風,羊致清和TCP/IP協(xié)議TCP/IP協(xié)議數據發(fā)送和數據接收馬馳率風,羊致清和TCP協(xié)議TCP協(xié)議的三次握手馬馳率風,羊致清和UDP協(xié)議UDPUDP協(xié)議又被稱為用戶數據包協(xié)議(UserDatagramProtocol),它是面向無連接的協(xié)議,只要知道對方的IP地址和端口,就可以直接發(fā)送數據包,由于是面向無連接的,所以無法保證數據一定會到達接收方。馬馳率風,羊致清和端口號什么是端口號呢?區(qū)分計算機中的運行的應用程序的整數端口號的取值范圍是0到65535,一共65536個,其中80這個端口號分配給了HTTP服務,21這個端口號分配給了FTP服務。馬馳率風,羊致清和TCP協(xié)議與UDP協(xié)議的區(qū)別TCP協(xié)議UDP協(xié)議連接方面面向連接的面向無連接安全方面?zhèn)鬏斚⒖煽俊⒉粊G失、按順序到達無法保證不丟包傳輸效率方面?zhèn)鬏斝氏鄬^低傳輸效率高連接對象數量方面只能是點對點、一對一支持一對一、一對多、多對多的交互通信馬馳率風,羊致清和Socket簡介Socket通信模擬圖馬馳率風,羊致清和Socket對象的常用方法方法名稱功能描述bind((ip,port))綁定IP地址和端口listen(N)開始TCP監(jiān)聽,N表示操作系統(tǒng)掛起的最大連接數量,取值范圍1-5之間,一般設置為5accept()被動接收TCP客戶端連接,阻塞式connect((ip,port))主動初始化TCP服務器連接recv(size)接收TCP數據,返回值為字符串類型,size表示要接收的最大數據量馬馳率風,羊致清和Socket對象的常用方法方法名稱功能描述send(str)發(fā)送TCP數據,返回值是要發(fā)送的字節(jié)數量sendall(str)完整發(fā)送TCP數據,將str中的數據發(fā)送到連接的套接字,返回之前嘗試發(fā)送所有數據,如果成功為None,失敗拋出異常recvfrom()接收UDP數據,返回值為一個元組(data,address),data表示接收的數據,address表示發(fā)送數據的套接字地址sendto(data,(ip,port))發(fā)送UDP數據,返回值是發(fā)送的字節(jié)數close()關閉套接字馬馳率風,羊致清和TCP編程TCP服務器端流程如下:使用socket類創(chuàng)建一個套接字對象使用bind((ip,port))方法綁定IP地址和端口號使用listen()方法開始TCP監(jiān)聽使用accept()方法等待客戶端的連接使用recv()/send()方法接收/發(fā)送數據使用close()關閉套接字馬馳率風,羊致清和TCP編程TCP客戶端的流程如下:使用socket類創(chuàng)建一個套接字對象使用connect((host,port))設置連接的主機IP和主機設置的端口號使用recv()/send()方法接收/發(fā)送數據使用close()關閉套接字馬馳率風,羊致清和TCP編程馬馳率風,羊致清和UDP編程馬馳率風,羊致清和本章總結網絡編程:在程序中實現網絡計算機之間的數據通信通信協(xié)議:接入網絡所要遵守的“規(guī)則”,目前全球通用的通信協(xié)議即Internet協(xié)議TCP/IP協(xié)議:中譯為“傳輸控制協(xié)議”/“因特網互聯協(xié)議”TCP/IP協(xié)議所對應的四層從下到上分別為:網絡接口層、網際層、傳輸層、應用層傳輸層的協(xié)議有:TCP協(xié)議、UDP協(xié)議TCP協(xié)議:面向連接的,可靠的、不丟失的、按順序到達,但傳輸效率相對較低,只能實現點對點,一對一的數據傳輸UDP協(xié)議:面向無連接,無法保證不丟包,但傳輸效率高,可以實現一對一、一對多,多對多的交互通信Python中的內置模塊socket支持TCP與UDP的編程馬馳率風,羊致清和本章總結TCP編程服務器端操作流程使用socket類創(chuàng)建一個套接字使用bind((ip,port))方法綁定IP地址和端口號使用listen()方法開始TCP監(jiān)聽使用accept()方法等待客戶端的連接使用recv()/send()方法接收/發(fā)送數據使用close()關閉套接字TCP編程客戶端操作流程使用socket類創(chuàng)建一個套接字使用connect((host,port))設置連接的主機IP和主機設置的端口號使用recv()/send()方法接收/發(fā)送數據使用close()關閉套接字TCP編程客戶端與服務器端啟動運行有先后,先啟動運行服務器端再啟動運行客戶端,連接建立之后雙方誰先發(fā)送數據均可馬馳率風,羊致清和本章總結UDP編程發(fā)送方操作流程使用socket類創(chuàng)建一個套接字對象準備發(fā)送的數據定義接收方的IP地址和端口號使用sendto()方法發(fā)送數據關閉socket對象UDP編程接收方操作流程使用socket類創(chuàng)建一個套接字對象使用bind()方法綁定IP地址和端口號使用recvfrom()方法接收發(fā)送過來的數據關閉socket對象UDP編程接收方與發(fā)送方啟動運行無先后,但先啟動運行發(fā)送方,數據會丟包馬馳率風,羊致清和章節(jié)習題1)以下選項中,是TCP/IP體系中傳輸層最重要的協(xié)議之一是:(

A.TCP

B.FTP

C.DNS

D.HTTPA馬馳率風,羊致清和章節(jié)習題2)關于UDP以下描述正確的是:(

A.發(fā)送數據包之前先連接目標服務器設備

B.發(fā)送數據包之前不需要先連接目標服務器設備

C.需要通過三次握手相互確認信息

D.UDP發(fā)送的數據是點對點的一對一的B馬馳率風,羊致清和章節(jié)習題3)關于TCP協(xié)議的描述,以下錯誤的是:(

A.面向連接

B.可靠傳輸

C.效率相對UDP要低一些

D.報文頭部長,傳輸開銷大D馬馳率風,羊致清和章節(jié)習題4)為了保證連接的可靠性,TCP通常采用:(

A.3次握手

B.自動重傳機制

C.端口機制

D.滑動窗口機制A馬馳率風,羊致清和章節(jié)習

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論