日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

Python3之socket编程(TCP/UDP,粘包问题,数据传输、文件上传)

發(fā)布時間:2025/3/15 python 55 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python3之socket编程(TCP/UDP,粘包问题,数据传输、文件上传) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

一、socket的定義

  Socket是應(yīng)用層與TCP/IP協(xié)議族通信的中間軟件抽象層,它是一組接口。在設(shè)計(jì)模式中,Socket其實(shí)就是一個門面模式,它把復(fù)雜的TCP/IP協(xié)議族隱藏在Socket接口后面,對用戶來說,一組簡單的接口就是全部,讓Socket去組織數(shù)據(jù),以符合指定的協(xié)議。所以,我們無需深入理解tcp/udp協(xié)議,socket已經(jīng)為我們封裝好了,我們只需要遵循socket的規(guī)定去編程,寫出的程序自然就是遵循tcp/udp標(biāo)準(zhǔn)的。

補(bǔ)充:也有人將socket說成ip+port,ip是用來標(biāo)識互聯(lián)網(wǎng)中的一臺主機(jī)的位置,而port是用來標(biāo)識這臺機(jī)器上的一個應(yīng)用程序,ip地址是配置到網(wǎng)卡上的,而port是應(yīng)用程序開啟的,ip與port的綁定就標(biāo)識了互聯(lián)網(wǎng)中獨(dú)一無二的一個應(yīng)用程序,而程序的pid是同一臺機(jī)器上不同進(jìn)程或者線程的標(biāo)識

二、套接字發(fā)展史及分類

  套接字起源于 20 世紀(jì) 70 年代加利福尼亞大學(xué)伯克利分校版本的 Unix,即人們所說的 BSD Unix。 因此,有時人們也把套接字稱為“伯克利套接字”或“BSD 套接字”。一開始,套接字被設(shè)計(jì)用在同 一臺主機(jī)上多個應(yīng)用程序之間的通訊。這也被稱進(jìn)程間通訊,或 IPC。套接字有兩種(或者稱為有兩個種族),分別是基于文件型的和基于網(wǎng)絡(luò)型的。?

  • 基于文件類型的套接字家族

套接字家族的名字:AF_UNIX

unix一切皆文件,基于文件的套接字調(diào)用的就是底層的文件系統(tǒng)來取數(shù)據(jù),兩個套接字進(jìn)程運(yùn)行在同一機(jī)器,可以通過訪問同一個文件系統(tǒng)間接完成通信

  • 基于網(wǎng)絡(luò)類型的套接字家族

套接字家族的名字:AF_INET

(還有AF_INET6被用于ipv6,還有一些其他的地址家族,不過,他們要么是只用于某個平臺,要么就是已經(jīng)被廢棄,或者是很少被使用,或者是根本沒有實(shí)現(xiàn),所有地址家族中,AF_INET是使用最廣泛的一個,python支持很多種地址家族,但是由于我們只關(guān)心網(wǎng)絡(luò)編程,所以大部分時候我么只使用AF_INET)

三、套接字的工作流程

?   一個生活中的場景。你要打電話給一個朋友,先撥號,朋友聽到電話鈴聲后提起電話,這時你和你的朋友就建立起了連接,就可以講話了。等交流結(jié)束,掛斷電話結(jié)束此次交談。

生活中的場景就解釋了套接字的工作原理

先從服務(wù)器端說起。服務(wù)器端先初始化Socket,然后與端口綁定(bind),對端口進(jìn)行監(jiān)聽(listen),調(diào)用accept阻塞,等待客戶端連接。在這時如果有個客戶端初始化一個Socket,然后連接服務(wù)器(connect),如果連接成功,這時客戶端與服務(wù)器端的連接就建立了。客戶端發(fā)送數(shù)據(jù)請求,服務(wù)器端接收請求并處理請求,然后把回應(yīng)數(shù)據(jù)發(fā)送給客戶端,客戶端讀取數(shù)據(jù),最后關(guān)閉連接,一次交互結(jié)束。

?

四、socket函數(shù)使用

  • socket函數(shù)用法
import socket socket.socket(socket_family,socket_type,protocal=0) #socket_family 可以是 AF_UNIX 或 AF_INET。socket_type 可以是 SOCK_STREAM 或 SOCK_DGRAM。protocol 一般不填,默認(rèn)值為 0。#獲取tcp/ip套接字 tcpSock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)#獲取udp/ip套接字 udpSock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)#由于 socket 模塊中有太多的屬性。我們在這里破例使用了'from module import *'語句。使用 'from socket import *',我們就把 socket 模塊里的所有屬性都帶到我們的命名空間里了,這樣能 大幅減短我們的代碼。 #例如tcpSock = socket(AF_INET, SOCK_STREAM)
  • 服務(wù)端套接字函數(shù)
s.bind() #綁定(主機(jī),端口號)到套接字 s.listen() #開始TCP監(jiān)聽 s.accept() #被動接受TCP客戶的連接,(阻塞式)等待連接的到來
  • 客戶端套接字函數(shù)
s.connect() #主動初始化TCP服務(wù)器連接 s.connect_ex() #connect()函數(shù)的擴(kuò)展版本,出錯時返回出錯碼,而不是拋出異常
  • 公共用途的套接字函數(shù)
s.recv() #接收TCP數(shù)據(jù) s.send() #發(fā)送TCP數(shù)據(jù)(send在待發(fā)送數(shù)據(jù)量大于己端緩存區(qū)剩余空間時,數(shù)據(jù)丟失,不會發(fā)完) s.sendall() #發(fā)送完整的TCP數(shù)據(jù)(本質(zhì)就是循環(huán)調(diào)用send,sendall在待發(fā)送數(shù)據(jù)量大于己端緩存區(qū)剩余空間時,數(shù)據(jù)不丟失,循環(huán)調(diào)用send直到發(fā)完) s.recvfrom() #接收UDP數(shù)據(jù) s.sendto() #發(fā)送UDP數(shù)據(jù) s.getpeername() #連接到當(dāng)前套接字的遠(yuǎn)端的地址 s.getsockname() #當(dāng)前套接字的地址 s.getsockopt() #返回指定套接字的參數(shù) s.setsockopt() #設(shè)置指定套接字的參數(shù) s.close() #關(guān)閉套接字
  • 面向鎖的套接字方法
s.setblocking() #設(shè)置套接字的阻塞與非阻塞模式 s.settimeout() #設(shè)置阻塞套接字操作的超時時間 s.gettimeout() #得到阻塞套接字操作的超時時間
  • 面向文件的套接字方法
s.fileno() #套接字的文件描述符 s.makefile() #創(chuàng)建一個與該套接字相關(guān)的文件

?

打電話的流程演示

服務(wù)端.py

import socket phone=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #買手機(jī) phone.bind(('127.0.0.1',8080)) #插電話卡phone.listen(5) #開機(jī),backlogprint('starting....') conn,addr=phone.accept() #接電話 print(conn) print('client addr',addr) print('ready to read msg') client_msg=conn.recv(1024) #收消息 print('client msg: %s' %client_msg) conn.send(client_msg.upper()) #發(fā)消息conn.close() phone.close()

客戶端.py

import socket phone=socket.socket(socket.AF_INET,socket.SOCK_STREAM) phone.connect(('127.0.0.1',8080)) #撥通電話phone.send('hello'.encode('utf-8')) #發(fā)消息back_msg=phone.recv(1024) print(back_msg)phone.close()

輸出

服務(wù)端:

starting.... <socket.socket fd=4, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('127.0.0.1', 8080), raddr=('127.0.0.1', 65142)> client addr ('127.0.0.1', 65142) ready to read msg client msg: b'hello'

客戶端

b'HELLO'

?

五、基于TCP的套接字

  • tcp服務(wù)端?
ss = socket() #創(chuàng)建服務(wù)器套接字 ss.bind() #把地址綁定到套接字 ss.listen() #監(jiān)聽鏈接 inf_loop: #服務(wù)器無限循環(huán)cs = ss.accept() #接受客戶端鏈接comm_loop: #通訊循環(huán)cs.recv()/cs.send() #對話(接收與發(fā)送)cs.close() #關(guān)閉客戶端套接字 ss.close() #關(guān)閉服務(wù)器套接字(可選)
  • tcp客戶端
cs = socket() # 創(chuàng)建客戶套接字 cs.connect() # 嘗試連接服務(wù)器 comm_loop: # 通訊循環(huán)cs.send()/cs.recv() # 對話(發(fā)送/接收) cs.close() # 關(guān)閉客戶套接字

socket通信流程與打電話流程類似,我們就以打電話為例來實(shí)現(xiàn)一個low版的套接字通信

服務(wù)端

import socket ip_port=('127.0.0.1',9000) #電話卡 BUFSIZE=1024 #收發(fā)消息的尺寸 s=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #買手機(jī) s.bind(ip_port) #手機(jī)插卡 s.listen(5) #手機(jī)待機(jī)conn,addr=s.accept() #手機(jī)接電話 # print(conn) # print(addr) print('接到來自%s的電話' %addr[0])msg=conn.recv(BUFSIZE) #聽消息,聽話 print(msg,type(msg))conn.send(msg.upper()) #發(fā)消息,說話conn.close() #掛電話s.close() #手機(jī)關(guān)機(jī)

客戶端

import socket ip_port=('127.0.0.1',9000) BUFSIZE=1024 s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)s.connect_ex(ip_port) #撥電話s.send('nitouxiang nb'.encode('utf-8')) #發(fā)消息,說話(只能發(fā)送字節(jié)類型)feedback=s.recv(BUFSIZE) #收消息,聽話 print(feedback.decode('utf-8'))s.close() #掛電話

輸出

服務(wù)端

接到來自127.0.0.1的電話 b'nitouxiang nb' <class 'bytes'>

客戶端

NITOUXIANG NB

?

上述流程的問題是,服務(wù)端只能接受一次鏈接,然后就徹底關(guān)閉掉了,實(shí)際情況應(yīng)該是,服務(wù)端不斷接受鏈接,然后循環(huán)通信,通信完畢后只關(guān)閉鏈接,服務(wù)器能夠繼續(xù)接收下一次鏈接,下面是修改版

?服務(wù)端

import socket ip_port = ('127.0.0.1',8081) #電話卡 BUFSIZE=1024 s=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #買手機(jī) s.bind(ip_port) #手機(jī)插卡 s.listen(5) #手機(jī)待機(jī)while True: #新增接收鏈接循環(huán),可以不停的接電話conn,addr=s.accept() #手機(jī)接電話print('接到來自%s的電話' %addr[0])while True: ##新增通信循環(huán),可以不斷的通信,收發(fā)消息msg=conn.recv(BUFSIZE) #聽消息,聽話if len(msg) == 0:break #如果不加,那么正在鏈接的客戶端突然斷開,recv便不再阻塞,死循環(huán)發(fā)生print(msg,type(msg))conn.send(msg.upper()) #發(fā)消息,說話conn.close() #掛電話 s.close() #手機(jī)關(guān)機(jī)

客戶端

import socket ip_port=('127.0.0.1',8081) BUFSIZE=1024 s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)s.connect_ex(ip_port) #撥電話while True: #新增通信循環(huán),客戶端可以不斷發(fā)收消息msg=input('>>: ').strip()if len(msg) == 0:continues.send(msg.encode('utf-8')) #發(fā)消息,說話(只能發(fā)送字節(jié)類型)feedback=s.recv(BUFSIZE) #收消息,聽話print(feedback.decode('utf-8'))s.close() #掛電話

補(bǔ)充:

在重啟服務(wù)端時可能會遇到

這個是由于你的服務(wù)端仍然存在四次揮手的time_wait狀態(tài)在占用地址(如果不懂,請深入研究1.tcp三次握手,四次揮手 2.syn洪水攻擊 3.服務(wù)器高并發(fā)情況下會有大量的time_wait狀態(tài)的優(yōu)化方法)

解決辦法

方法一

#加入一條socket配置,重用ip和端口phone=socket(AF_INET,SOCK_STREAM) phone.setsockopt(SOL_SOCKET,SO_REUSEADDR,1) #就是它,在bind前加 phone.bind(('127.0.0.1',8080))

方法二

發(fā)現(xiàn)系統(tǒng)存在大量TIME_WAIT狀態(tài)的連接,通過調(diào)整linux內(nèi)核參數(shù)解決, vi /etc/sysctl.conf編輯文件,加入以下內(nèi)容: net.ipv4.tcp_syncookies = 1 net.ipv4.tcp_tw_reuse = 1 net.ipv4.tcp_tw_recycle = 1 net.ipv4.tcp_fin_timeout = 30然后執(zhí)行 /sbin/sysctl -p 讓參數(shù)生效。net.ipv4.tcp_syncookies = 1 表示開啟SYN Cookies。當(dāng)出現(xiàn)SYN等待隊(duì)列溢出時,啟用cookies來處理,可防范少量SYN攻擊,默認(rèn)為0,表示關(guān)閉;net.ipv4.tcp_tw_reuse = 1 表示開啟重用。允許將TIME-WAIT sockets重新用于新的TCP連接,默認(rèn)為0,表示關(guān)閉;net.ipv4.tcp_tw_recycle = 1 表示開啟TCP連接中TIME-WAIT sockets的快速回收,默認(rèn)為0,表示關(guān)閉。net.ipv4.tcp_fin_timeout 修改系統(tǒng)默認(rèn)的 TIMEOUT 時間

六、基于UDP的套接字

  • udp服務(wù)端
ss = socket() #創(chuàng)建一個服務(wù)器的套接字 ss.bind() #綁定服務(wù)器套接字 inf_loop: #服務(wù)器無限循環(huán)cs = ss.recvfrom()/ss.sendto() # 對話(接收與發(fā)送) ss.close() # 關(guān)閉服務(wù)器套接字
  • udp客戶端
cs = socket() # 創(chuàng)建客戶套接字 comm_loop: # 通訊循環(huán)cs.sendto()/cs.recvfrom() # 對話(發(fā)送/接收) cs.close() # 關(guān)閉客戶套接字

示例

服務(wù)端

import socket ip_port=('127.0.0.1',9000) BUFSIZE=1024 udp_server_client=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)udp_server_client.bind(ip_port)while True:msg,addr=udp_server_client.recvfrom(BUFSIZE)print(msg,addr)udp_server_client.sendto(msg.upper(),addr)

客戶端

import socket ip_port=('127.0.0.1',9000) BUFSIZE=1024 udp_server_client=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)while True:msg=input('>>: ').strip()if not msg:continueudp_server_client.sendto(msg.encode('utf-8'),ip_port)back_msg,addr=udp_server_client.recvfrom(BUFSIZE)print(back_msg.decode('utf-8'),addr)

輸出

客戶端

>>: 123 123 ('127.0.0.1', 9000) >>: 3 3 ('127.0.0.1', 9000) >>: 4 4 ('127.0.0.1', 9000)

服務(wù)端

b'123' ('127.0.0.1', 53066) b'3' ('127.0.0.1', 53066) b'4' ('127.0.0.1', 53066)

?

模擬QQ聊天,多個客戶端和服務(wù)端通信

服務(wù)端

import socket ip_port=('127.0.0.1',8081) udp_server_sock=socket.socket(socket.AF_INET,socket.SOCK_DGRAM) #買手機(jī) udp_server_sock.bind(ip_port)while True:qq_msg,addr=udp_server_sock.recvfrom(1024)print('來自[%s:%s]的一條消息:\033[1;44m%s\033[0m' %(addr[0],addr[1],qq_msg.decode('utf-8')))back_msg=input('回復(fù)消息: ').strip()udp_server_sock.sendto(back_msg.encode('utf-8'),addr)

客戶端1

import socket BUFSIZE=1024 udp_client_socket=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)qq_name_dic={'TOM':('127.0.0.1',8081),'JACK':('127.0.0.1',8081),'一棵樹':('127.0.0.1',8081),'武大郎':('127.0.0.1',8081), }while True:qq_name=input('請選擇聊天對象: ').strip()while True:msg=input('請輸入消息,回車發(fā)送: ').strip()if msg == 'quit':breakif not msg or not qq_name or qq_name not in qq_name_dic:continueudp_client_socket.sendto(msg.encode('utf-8'),qq_name_dic[qq_name])back_msg,addr=udp_client_socket.recvfrom(BUFSIZE)print('來自[%s:%s]的一條消息:\033[1;44m%s\033[0m' %(addr[0],addr[1],back_msg.decode('utf-8')))udp_client_socket.close()

客戶端2

import socket BUFSIZE=1024 udp_client_socket=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)qq_name_dic={'TOM':('127.0.0.1',8081),'JACK':('127.0.0.1',8081),'一棵樹':('127.0.0.1',8081),'武大郎':('127.0.0.1',8081), }while True:qq_name=input('請選擇聊天對象: ').strip()while True:msg=input('請輸入消息,回車發(fā)送: ').strip()if msg == 'quit':breakif not msg or not qq_name or qq_name not in qq_name_dic:continueudp_client_socket.sendto(msg.encode('utf-8'),qq_name_dic[qq_name])back_msg,addr=udp_client_socket.recvfrom(BUFSIZE)print('來自[%s:%s]的一條消息:\033[1;44m%s\033[0m' %(addr[0],addr[1],back_msg.decode('utf-8')))udp_client_socket.close()

輸出

客戶端1

請選擇聊天對象: JACK 請輸入消息,回車發(fā)送: 約不 來自[127.0.0.1:8081]的一條消息:不約 請輸入消息,回車發(fā)送:

客戶端2

請選擇聊天對象: TOM 請輸入消息,回車發(fā)送: 123 來自[127.0.0.1:8081]的一條消息:321 請輸入消息,回車發(fā)送:

服務(wù)端

來自[127.0.0.1:62851]的一條消息:123 回復(fù)消息: 321 來自[127.0.0.1:60378]的一條消息:約不 回復(fù)消息: 不約

?

七、recv與recvfrom

發(fā)消息,都是將數(shù)據(jù)發(fā)送到己端的發(fā)送緩沖中,收消息都是從己端的緩沖區(qū)中收。

  • tcp:send發(fā)消息,recv收消息
  • udp:sendto發(fā)消息,recvfrom收消息

?1.send與sendinto

tcp是基于數(shù)據(jù)流的,而udp是基于數(shù)據(jù)報(bào)的:

  • send(bytes_data):發(fā)送數(shù)據(jù)流,數(shù)據(jù)流bytes_data若為空,自己這段的緩沖區(qū)也為空,操作系統(tǒng)不會控制tcp協(xié)議發(fā)空包
  • sendinto(bytes_data,ip_port):發(fā)送數(shù)據(jù)報(bào),bytes_data為空,還有ip_port,所有即便是發(fā)送空的bytes_data,數(shù)據(jù)報(bào)其實(shí)也不是空的,自己這端的緩沖區(qū)收到內(nèi)容,操作系統(tǒng)就會控制udp協(xié)議發(fā)包。

?

2.recv與recvfrom

tcp協(xié)議:

(1)如果收消息緩沖區(qū)里的數(shù)據(jù)為空,那么recv就會阻塞(阻塞很簡單,就是一直在等著收)

(2)只不過tcp協(xié)議的客戶端send一個空數(shù)據(jù)就是真的空數(shù)據(jù),客戶端即使有無窮個send空,也跟沒有一個樣。

(3)tcp基于鏈接通信

  • 基于鏈接,則需要listen(backlog),指定半連接池的大小
  • 基于鏈接,必須先運(yùn)行的服務(wù)端,然后客戶端發(fā)起鏈接請求
  • 對于mac系統(tǒng):如果一端斷開了鏈接,那另外一端的鏈接也跟著完蛋recv將不會阻塞,收到的是空(解決方法是:服務(wù)端在收消息后加上if判斷,空消息就break掉通信循環(huán))
  • 對于windows/linux系統(tǒng):如果一端斷開了鏈接,那另外一端的鏈接也跟著完蛋recv將不會阻塞,收到的是空(解決方法是:服務(wù)端通信循環(huán)內(nèi)加異常處理,捕捉到異常后就break掉通訊循環(huán))

?

udp協(xié)議

(1)如果如果收消息緩沖區(qū)里的數(shù)據(jù)為“空”,recvfrom也會阻塞

(2)只不過udp協(xié)議的客戶端sendinto一個空數(shù)據(jù)并不是真的空數(shù)據(jù)(包含:空數(shù)據(jù)+地址信息,得到的報(bào)仍然不會為空),所以客戶端只要有一個sendinto(不管是否發(fā)送空數(shù)據(jù),都不是真的空數(shù)據(jù)),服務(wù)端就可以recvfrom到數(shù)據(jù)。

(3)udp無鏈接

  • 無鏈接,因而無需listen(backlog),更加沒有什么連接池之說了
  • 無鏈接,udp的sendinto不用管是否有一個正在運(yùn)行的服務(wù)端,可以己端一個勁的發(fā)消息,只不過數(shù)據(jù)丟失
  • recvfrom收的數(shù)據(jù)小于sendinto發(fā)送的數(shù)據(jù)時,在mac和linux系統(tǒng)上數(shù)據(jù)直接丟失,在windows系統(tǒng)上發(fā)送的比接收的大直接報(bào)錯
  • 只有sendinto發(fā)送數(shù)據(jù)沒有recvfrom收數(shù)據(jù),數(shù)據(jù)丟失?

注意:

1.你單獨(dú)運(yùn)行上面的udp的客戶端,你發(fā)現(xiàn)并不會報(bào)錯,相反tcp卻會報(bào)錯,因?yàn)閡dp協(xié)議只負(fù)責(zé)把包發(fā)出去,對方收不收,我根本不管,而tcp是基于鏈接的,必須有一個服務(wù)端先運(yùn)行著,客戶端去跟服務(wù)端建立鏈接然后依托于鏈接才能傳遞消息,任何一方試圖把鏈接摧毀都會導(dǎo)致對方程序的崩潰。

2.上面的udp程序,你注釋任何一條客戶端的sendinto,服務(wù)端都會卡住,為什么?因?yàn)榉?wù)端有幾個recvfrom就要對應(yīng)幾個sendinto,哪怕是sendinto(b'')那也要有。

?

基于tcp先制作一個遠(yuǎn)程執(zhí)行命令的程序(1:執(zhí)行錯誤命令 2:執(zhí)行l(wèi)s 3:執(zhí)行ifconfig)

客戶端

import socket BUFSIZE=1024 ip_port=('127.0.0.1',8080)s=socket.socket(socket.AF_INET,socket.SOCK_STREAM) res=s.connect_ex(ip_port)while True:msg=input('>>: ').strip()if len(msg) == 0:continueif msg == 'quit':breaks.send(msg.encode('utf-8'))act_res=s.recv(BUFSIZE)print(act_res.decode('utf-8'),end='')

服務(wù)端

from socket import * import subprocessip_port=('127.0.0.1',8080) BUFSIZE=1024tcp_socket_server=socket(AF_INET,SOCK_STREAM) tcp_socket_server.setsockopt(SOL_SOCKET,SO_REUSEADDR,1) tcp_socket_server.bind(ip_port) tcp_socket_server.listen(5)while True:conn,addr=tcp_socket_server.accept()print('客戶端',addr)while True:cmd=conn.recv(BUFSIZE)if len(cmd) == 0:breakres=subprocess.Popen(cmd.decode('utf-8'),shell=True,stdout=subprocess.PIPE,stdin=subprocess.PIPE,stderr=subprocess.PIPE)stderr=res.stderr.read()stdout=res.stdout.read()conn.send(stderr)conn.send(stdout)

輸出

客戶端

>>: ls 1.py 客戶端.py 客戶端1.py 客戶端2.py 服務(wù)端.py >>: ifconfig en0 en0: flags=8863<UP,BROADCAST,SMART,RUNNING,SIMPLEX,MULTICAST> mtu 1500ether 78:4f:43:5b:a5:4c inet6 fe80::d0:d821:dbf0:3d67%en0 prefixlen 64 secured scopeid 0x5 inet 192.168.31.165 netmask 0xffffff00 broadcast 192.168.31.255nd6 options=201<PERFORMNUD,DAD>media: autoselectstatus: active >>: ifconfig lo0: flags=8049<UP,LOOPBACK,RUNNING,MULTICAST> mtu 16384options=1203<RXCSUM,TXCSUM,TXSTATUS,SW_TIMESTAMP>inet 127.0.0.1 netmask 0xff000000 inet6 ::1 prefixlen 128 inet6 fe80::1%lo0 prefixlen 64 scopeid 0x1 nd6 options=201<PERFORMNUD,DAD> gif0: flags=8010<POINTOPOINT,MULTICAST> mtu 1280 stf0: flags=0<> mtu 1280 en0: flags=8863<UP,BROADCAST,SMART,RUNNING,SIMPLEX,MULTICAST> mtu 1500ether 78:4f:43:5b:a5:4c inet6 fe80::d0:d821:dbf0:3d67%en0 prefixlen 64 secured scopeid 0x5 inet 192.168.31.165 netmask 0xffffff00 broadcast 192.168.31.255nd6 options=201<PERFORMNUD,DAD>media: autoselectstatus: active en1: flags=963<UP,BROADCAST,SMART,RUNNING,PROMISC,SIMPLEX> mtu 1500options=60<TSO4,TSO6>ether e2:00:ec:98:eb:00 media: autoselect <full-duplex>status: inactive en3: flags=963<UP,BROADCAST,SMART,RUNNING,PROMISC,SIMPLEX> mtu 1500options=60<TSO4,TSO6>ether e2:00:ec:98:eb:01 media: autoselect <full-duplex>status: inactive en2: flags=963<UP,BROADCAST,SMART,RUNNING,PROMISC,SIMPLEX> mtu 1500>>: >>:

服務(wù)端

客戶端 ('127.0.0.1', 58194)

上述程序是基于tcp的socket,在運(yùn)行時會發(fā)生粘包

?

服務(wù)端

from socket import * import subprocessip_port=('127.0.0.1',9003) bufsize=1024udp_server=socket(AF_INET,SOCK_DGRAM) udp_server.bind(ip_port)while True:#收消息cmd,addr=udp_server.recvfrom(bufsize)print('用戶命令----->',cmd)#邏輯處理res=subprocess.Popen(cmd.decode('utf-8'),shell=True,stderr=subprocess.PIPE,stdin=subprocess.PIPE,stdout=subprocess.PIPE)stderr=res.stderr.read()stdout=res.stdout.read()#發(fā)消息udp_server.sendto(stderr,addr)udp_server.sendto(stdout,addr) udp_server.close()

客戶端

from socket import * ip_port=('127.0.0.1',9003) bufsize=1024udp_client=socket(AF_INET,SOCK_DGRAM)while True:msg=input('>>: ').strip()udp_client.sendto(msg.encode('utf-8'),ip_port)data,addr=udp_client.recvfrom(bufsize)print(data.decode('utf-8'),end='')

上述程序是基于udp的socket,在運(yùn)行時永遠(yuǎn)不會發(fā)生粘包

?

注意注意注意:

res=subprocess.Popen(cmd.decode('utf-8'),
shell=True,
stderr=subprocess.PIPE,
stdout=subprocess.PIPE)

的結(jié)果的編碼是以當(dāng)前所在的系統(tǒng)為準(zhǔn)的,如果是windows,那么res.stdout.read()讀出的就是GBK編碼的,在接收端需要用GBK解碼且只能從管道里讀一次結(jié)果

?

八、粘包

1.什么是粘包

粘包:發(fā)送方發(fā)送兩個字符串”hello”+”world”,接收方卻一次性接收到了”helloworld”。

只有TCP有粘包現(xiàn)象,UDP永遠(yuǎn)不會粘包。

所謂粘包問題主要還是因?yàn)榻邮辗讲恢老⒅g的界限,不知道一次性提取多少字節(jié)的數(shù)據(jù)所造成的。

補(bǔ)充:

分包:發(fā)送方發(fā)送字符串”helloworld”,接收方卻接收到了兩個字符串”hello”和”world”。

TCP是以段(Segment)為單位發(fā)送數(shù)據(jù)的,建立TCP鏈接后,有一個最大消息長度(MSS)。如果應(yīng)用層數(shù)據(jù)包超過MSS,就會把應(yīng)用層數(shù)據(jù)包拆分,分成兩個段來發(fā)送。這個時候接收端的應(yīng)用層就要拼接這兩個TCP包,才能正確處理數(shù)據(jù)。

補(bǔ)充:

一個socket收發(fā)消息的原理

2.粘包如何產(chǎn)生

TCP為了提高網(wǎng)絡(luò)的利用率,會使用一個叫做Nagle的算法。該算法是指,發(fā)送端即使有要發(fā)送的數(shù)據(jù),如果很少的話,會延遲發(fā)送。如果應(yīng)用層給TCP傳送數(shù)據(jù)很快的話,就會把兩個應(yīng)用層數(shù)據(jù)包“粘”在一起,TCP最后只發(fā)一個TCP數(shù)據(jù)包給接收端。

tcp的協(xié)議數(shù)據(jù)不會丟,沒有收完包,下次接收,會繼續(xù)上次繼續(xù)接收,己端總是在收到ack時才會清除緩沖區(qū)內(nèi)容。數(shù)據(jù)是可靠的,但是會粘包。

?

反送方:

當(dāng)應(yīng)用程序調(diào)用send函數(shù)時,應(yīng)用程序會將數(shù)據(jù)從應(yīng)用程序拷貝到操作系統(tǒng)緩存,再由操作系統(tǒng)從緩沖區(qū)讀取數(shù)據(jù)并發(fā)送出去

接收方:

對方計(jì)算機(jī)收到數(shù)據(jù)也是操作系統(tǒng)先收到,至于應(yīng)用程序何時處理這些數(shù)據(jù),操作系統(tǒng)并不清楚,所以同樣需要將數(shù)據(jù)先存儲到操作系統(tǒng)的緩沖區(qū)中,當(dāng)應(yīng)用程序調(diào)用recv時,實(shí)際上是從操作系統(tǒng)緩沖區(qū)中將數(shù)據(jù)拷貝到應(yīng)用程序的過程

上述過程對于TCP與UDP都是相同的不同之處在于:

UDP:

UDP在收發(fā)數(shù)據(jù)時是基于數(shù)據(jù)包的,即一個包一個包的發(fā)送,包與包之間有著明確的分界,到達(dá)對方操作系統(tǒng)緩沖區(qū)后也是一個一個獨(dú)立的數(shù)據(jù)包,接收方從操作系統(tǒng)緩沖區(qū)中將數(shù)據(jù)包拷貝到應(yīng)用程序

這種方式存在的問題:

  • 發(fā)送方發(fā)送的數(shù)據(jù)長度每個操作系統(tǒng)會有不同的限制,數(shù)據(jù)超過限制則無法發(fā)送
  • 接收方接收數(shù)據(jù)時如果應(yīng)用程序的提供的緩存容量小于數(shù)據(jù)包的長度將造成數(shù)據(jù)丟失,而緩沖區(qū)大小不可能無限大
  • TCP:

    當(dāng)我們需要傳輸較大的數(shù)據(jù),或需要保證數(shù)據(jù)完整性時,最簡單的方式就是使用TCP協(xié)議了,與UDP不同的是,TCP增加了一套校驗(yàn)規(guī)則來保證數(shù)據(jù)的完整性,會將超過TCP包最大長度的數(shù)據(jù)拆分為多個TCP包,并在傳輸數(shù)據(jù)時為每一個TCP數(shù)據(jù)包指定一個順序號,接收方在收到TCP數(shù)據(jù)包后按照順序?qū)?shù)據(jù)包進(jìn)行重組,重組后的數(shù)據(jù)全都是二進(jìn)制數(shù)據(jù),且每次收到的二進(jìn)制數(shù)據(jù)之間沒有明顯的分界

    基于這種工作機(jī)制TCP在三種情況下會發(fā)送粘包問題

  • 當(dāng)單個數(shù)據(jù)包較小時接收方可能一次性讀取了多個包的數(shù)據(jù)
  • 當(dāng)整體數(shù)據(jù)較大時接收方可能一次僅讀取了一個包的一部分內(nèi)容
  • 另外TCP協(xié)議為了提高效率,增加了一種優(yōu)化機(jī)制,會將數(shù)據(jù)較小且發(fā)送間隔較短的數(shù)據(jù)合并發(fā)送,該機(jī)制也會導(dǎo)致發(fā)送方將兩個數(shù)據(jù)包粘在一起發(fā)送
  • 基礎(chǔ)解決方案:

    首先明確只有TCP會出現(xiàn)粘包問題,之所以粘包是因?yàn)榻邮辗讲恢酪淮卧摻邮盏臄?shù)據(jù)長度,那如何才能讓接收方知道數(shù)據(jù)的長度呢?

    解決方案:在發(fā)送數(shù)據(jù)前先發(fā)送數(shù)據(jù)長度

    cmd 服務(wù)端:

    import socket import subprocess import struct server = socket.socket() server.bind(("127.0.0.1",9090)) server.listen()while True:client,addr = server.accept()while True:try:#接收客戶端命令cmd = client.recv(1024).decode("utf-8")p = subprocess.Popen(cmd,shell=True,stdout=-1,stderr=-1)# data與err_data都是采用的系統(tǒng)編碼,windows是GBKdata = p.stdout.read()err_data = p.stderr.read()print("數(shù)據(jù)長度:%s" % (len(data) + len(err_data)))#計(jì)算數(shù)據(jù)長度length = len(data) + len(err_data)#將int類型的長度轉(zhuǎn)成字節(jié)len_data = struct.pack("i",length)# 先發(fā)送長度,在發(fā)真實(shí)數(shù)據(jù)有可能長度數(shù)據(jù)和真實(shí)數(shù)據(jù)黏在一起,而接收方不知道長度數(shù)據(jù)的字節(jié)數(shù) 導(dǎo)致黏包# 解決的方案就是 長度信息占的字節(jié)數(shù)固定死 整數(shù) 轉(zhuǎn)成一個固定長度字節(jié)# 先發(fā)送長度給客戶端 client.send(len_data)# 再發(fā)送數(shù)據(jù)給客戶端client.send(data)client.send(err_data)except ConnectionResetError:client.close()print("連接中斷......")break

    cmd 客戶端:

    import socket import structc = socket.socket() c.connect(("127.0.0.1",9090)) while True:cmd = input(">>:").strip()c.send(cmd.encode("utf-8"))# 先接收長度,長度固定為4個字節(jié)length = c.recv(4)# 轉(zhuǎn)換為整型len_data = struct.unpack("i",length)[0] print("數(shù)據(jù)長度為%s" % len_data)# 存儲已接收數(shù)據(jù)all_data = b"" # 已接收長度rcv_size = 0# 循環(huán)接收直到接收到的長度等于總長度while rcv_size < len_data:data = c.recv(1024)rcv_size += len(data)all_data += dataprint("接收長度%s" % rcv_size)print(all_data.decode("gbk"))

    上述方案已經(jīng)完美解決了粘包問題,但是擴(kuò)展性不高,例如我們要實(shí)現(xiàn)文件上傳下載,不光要傳輸文件數(shù)據(jù),還需要傳輸文件名字,md5值等等,如何能實(shí)現(xiàn)呢?

    解決方案:

    發(fā)送端:

  • 先將所有的額外信息打包到一個頭中
  • 然后先發(fā)送頭部數(shù)據(jù)
  • 最后發(fā)送真實(shí)數(shù)據(jù)
  • 接收端:

  • 接收固定長度的頭部長度數(shù)據(jù)
  • 根據(jù)長度數(shù)據(jù)獲取頭部數(shù)據(jù)
  • 根據(jù)頭部數(shù)據(jù)獲取真實(shí)數(shù)據(jù)
  • cmd 服務(wù)端:

    # 要求:不僅返回命令的結(jié)果 還要返回執(zhí)行命令的時間 執(zhí)行時間:2018/12/26 import socket import subprocess import struct import datetime import jsonserver = socket.socket() server.bind(("127.0.0.1",9090)) server.listen()while True:client,addr = server.accept()while True:try:# 接收命令cmd = client.recv(1024).decode("utf-8")p = subprocess.Popen(cmd,shell=True,stdout=-1,stderr=-1)# data與err_data都是采用的系統(tǒng)編碼,windows是GBKdata = p.stdout.read()err_data = p.stderr.read()print("數(shù)據(jù)長度:%s" % (len(data) + len(err_data)))# 計(jì)算真實(shí)數(shù)據(jù)長度length = len(data) + len(err_data)# 在發(fā)送數(shù)據(jù)之前發(fā)送額外的信息#t = "{執(zhí)行時間:%s 真實(shí)數(shù)據(jù)長度:%s" % (datetime.datetime.now(),length)# 把要發(fā)送的數(shù)據(jù)先存到字典中t = {}t["time"] = str(datetime.datetime.now())t["size"] = lengtht["filename"] = "a.mp4"t_json = json.dumps(t) # 得到j(luò)son格式字符串t_data = t_json.encode("utf-8") # 將json轉(zhuǎn)成了字節(jié)t_length = struct.pack("i",len(t_data))# 1.先發(fā)送額外信息的長度client.send(t_length)# 2.發(fā)送額外信息client.send(t_data)# 3.發(fā)送真實(shí)數(shù)據(jù)client.send(data)client.send(err_data)except ConnectionResetError:client.close()print("連接中斷......")break# 1.發(fā)送了真實(shí)數(shù)據(jù)長度 2.發(fā)送了額外信息長度 3.發(fā)送額外信息 4.發(fā)送真實(shí)數(shù)據(jù)

    cmd 客戶端:

    import socket import struct import jsonc = socket.socket() c.connect(("127.0.0.1",9090)) while True:cmd = input(">>>:")if not cmd:print("命令不能為空")continuec.send(cmd.encode("utf-8"))# 1.接收的是額外信息的長度length = c.recv(4)len_data = struct.unpack("i",length)[0] # 轉(zhuǎn)換為整型# 2.接收額外信息t_data = c.recv(len_data)print(t_data.decode("utf-8"))json_dic = json.loads(t_data.decode("utf-8"))print("執(zhí)行時間:%s" % json_dic["time"])data_size = json_dic["size"] # 得到數(shù)據(jù)長度all_data = b"" # 存儲已接收數(shù)據(jù)rcv_size = 0 # 已接收長度# 接收真實(shí)數(shù)據(jù)# 循環(huán)接收 直到 接收到的長度等于總長度while rcv_size < data_size:data = c.recv(1024)rcv_size += len(data)all_data += dataprint("接收長度%s" % rcv_size)print(all_data.decode("gbk"))

    文件上傳下載

    服務(wù)端:

    import socket import struct import json server = socket.socket() server.bind(("127.0.0.1",9090)) server.listen() client,addr = server.accept()f = open("接收到的文件",mode="wb")head_len = client.recv(4) json_len = struct.unpack("i",head_len)[0]json_str = client.recv(json_len).decode("utf-8") head = json.loads(json_str) print(head)recv_size = 0 while recv_size < head["size"]:data = client.recv(1024)f.write(data)recv_size += len(data)print("接收完成...")

    客戶端:

    import socket import os import json import struct c = socket.socket() c.connect(("127.0.0.1",9090))filepath= r"F:\測試.mp4" f = open(filepath,mode="rb")# 在發(fā)送數(shù)據(jù)前先發(fā)送報(bào)頭 head = {"size":os.path.getsize(filepath),"filename":"回顧.mp4"} json_data = json.dumps(head).encode("utf-8")json_len = struct.pack("i",len(json_data)) c.send(json_len) # 發(fā)長度 c.send(json_data) # 發(fā)報(bào)頭# 發(fā)數(shù)據(jù) while True:data = f.read(1024)if not data:break# 發(fā)送給服務(wù)器c.send(data)print("上傳完成...")

    其他實(shí)例:

    import json,struct #假設(shè)通過客戶端上傳1T:1073741824000的文件a.txt#為避免粘包,必須自定制報(bào)頭 header={'file_size':1073741824000,'file_name':'/a/b/c/d/e/a.txt','md5':'8f6fbf8347faa4924a76856701edb0f3'} #1T數(shù)據(jù),文件路徑和md5值#為了該報(bào)頭能傳送,需要序列化并且轉(zhuǎn)為bytes head_bytes=bytes(json.dumps(header),encoding='utf-8') #序列化并轉(zhuǎn)成bytes,用于傳輸#為了讓客戶端知道報(bào)頭的長度,用struck將報(bào)頭長度這個數(shù)字轉(zhuǎn)成固定長度:4個字節(jié) head_len_bytes=struct.pack('i',len(head_bytes)) #這4個字節(jié)里只包含了一個數(shù)字,該數(shù)字是報(bào)頭的長度#客戶端開始發(fā)送 conn.send(head_len_bytes) #先發(fā)報(bào)頭的長度,4個bytes conn.send(head_bytes) #再發(fā)報(bào)頭的字節(jié)格式 conn.sendall(文件內(nèi)容) #然后發(fā)真實(shí)內(nèi)容的字節(jié)格式#服務(wù)端開始接收 head_len_bytes=s.recv(4) #先收報(bào)頭4個bytes,得到報(bào)頭長度的字節(jié)格式 x=struct.unpack('i',head_len_bytes)[0] #提取報(bào)頭的長度head_bytes=s.recv(x) #按照報(bào)頭長度x,收取報(bào)頭的bytes格式 header=json.loads(json.dumps(header)) #提取報(bào)頭#最后根據(jù)報(bào)頭的內(nèi)容提取真實(shí)的數(shù)據(jù),比如 real_data_len=s.recv(header['file_size']) s.recv(real_data_len)

    ?

    總結(jié)

    以上是生活随笔為你收集整理的Python3之socket编程(TCP/UDP,粘包问题,数据传输、文件上传)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    久久天天操 | 午夜精品av | 国产免费叼嘿网站免费 | 久久久久久国产精品久久 | 日日躁夜夜躁xxxxaaaa | 狠色在线| 蜜桃视频精品 | 欧美极度另类 | 亚洲黄色小说网 | 99性视频| 婷婷综合电影 | 91福利在线导航 | av高清一区二区三区 | 免费看一级特黄a大片 | 亚洲成人频道 | 91最新网址在线观看 | 色播六月天| 亚洲四虎| 亚洲第一伊人 | 黄色软件大全网站 | 国产成人精品综合久久久 | 久久99国产精品免费网站 | 久久亚洲私人国产精品 | 亚洲欧美日本国产 | 99在线观看免费视频精品观看 | 国产福利电影网址 | 91看片网址 | 久久情爱| 一级久久精品 | 精品日韩在线 | 亚洲电影黄色 | 三级午夜片 | 婷婷中文字幕在线观看 | 三日本三级少妇三级99 | 国产精品视频内 | 美女视频黄是免费的 | 国产精品视频在线观看 | 国产丝袜美腿在线 | 国产精品久久久久免费观看 | 色婷婷视频在线 | 97香蕉久久超级碰碰高清版 | 久久久久久久久久久久久9999 | 国内精品久久天天躁人人爽 | 亚洲一级片免费观看 | 国产成人精品一区二区在线 | 9797在线看片亚洲精品 | 91精品国产自产在线观看 | 亚洲午夜久久久影院 | 2021久久| 欧美国产大片 | 激情电影在线观看 | 亚洲精品乱码 | 天天躁日日躁狠狠躁av中文 | 久草视频播放 | 亚洲在线精品 | 日韩高清www| 丁香婷婷激情国产高清秒播 | 亚洲永久国产精品 | 国产黄色av网站 | 色视频国产直接看 | 久久精品国产亚洲 | 91精品爽啪蜜夜国产在线播放 | 97视频在线免费观看 | 国产精品久久久网站 | 91精品第一页 | 欧美xxxx性xxxxx高清 | 国产欧美中文字幕 | 黄色一级大片在线免费看国产一 | 伊人伊成久久人综合网小说 | 成人性生交大片免费看中文网站 | 久久综合成人网 | 在线看黄网站 | 久久精品久久99精品久久 | 久久久av免费 | 手机看片午夜 | 国产伦精品一区二区三区高清 | 天天操夜夜拍 | 久久理伦片 | 久久激情视频 久久 | 国产麻豆剧传媒免费观看 | 特级大胆西西4444www | 精品日韩中文字幕 | 国产成人三级在线播放 | 五月天综合色激情 | 日韩一区二区三区在线看 | 国产视频2区 | 日韩高清网站 | 亚洲精品中文在线资源 | 91精品国产福利 | www.888av| 久久精品99精品国产香蕉 | 亚洲精品久久久久58 | 人人舔人人爽 | 99视频在线观看视频 | 日韩电影一区二区三区 | 丁香九月婷婷 | 视频精品一区二区三区 | 狠狠色丁香婷婷综合基地 | 国产高清视频在线播放一区 | 国产精品久久久久久五月尺 | 四虎在线免费视频 | 亚洲清纯国产 | 成人av片免费观看app下载 | 亚洲va天堂va欧美ⅴa在线 | 国产精品毛片久久久 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 黄色大片日本免费大片 | 亚洲日本在线一区 | 亚洲精品h | 99久e精品热线免费 99国产精品久久久久久久久久 | 91视频传媒 | 欧美在线1区 | 欧美色图30p | 欧美成人精品欧美一级乱 | 亚洲午夜久久久久久久久久久 | av黄色av | 91亚洲国产 | aav在线 | 天天操天天曰 | 伊人色综合久久天天网 | 日韩av区 | 狠狠操在线 | 婷婷激情av | 天天插综合网 | 韩国av免费观看 | 免费在线色电影 | aaa亚洲精品一二三区 | av在线播放快速免费阴 | 欧美性猛片 | 91免费的视频在线播放 | 99视频网站 | 国产专区视频在线 | 久久99国产精品免费 | 欧美日韩在线精品 | 久久69精品久久久久久久电影好 | 日韩午夜精品 | 国产在线播放一区二区 | 国产资源在线免费观看 | 精品福利视频在线 | 奇米影视8888 | 亚洲午夜精品在线观看 | 国产不卡视频 | 高清一区二区三区 | 婷婷色综合 | 中文字幕最新精品 | 少妇bbr搡bbb搡bbb | 六月婷色 | 久操视频在线免费看 | 亚洲激情久久 | 在线亚洲精品 | www.一区二区三区 | 国产小视频网站 | 欧美一区二区三区在线观看 | 欧美日韩成人一区 | 91在线观看视频网站 | 国产精品久久久久久久av电影 | 国产成人精品久久二区二区 | 干亚洲少妇| 开心综合网| 日本超碰在线 | 欧美午夜性| 在线观看亚洲精品 | 久久久免费毛片 | 久久久精品网 | 在线观看视频免费播放 | 久久久久久久综合色一本 | 又黄又爽又刺激视频 | 在线天堂日本 | 久久伊人爱 | 亚洲精品视频在线 | 9热精品| 日韩天堂网 | 久久久国产网站 | 日韩在线播放视频 | 色婷婷www | 色婷婷激情电影 | 中文字幕黄色网址 | 成年人免费观看在线视频 | 亚洲天天综合 | 中文字幕九九 | 在线免费观看视频一区二区三区 | 久久视频一区 | 在线视频一区观看 | 小草av在线播放 | 探花国产在线 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产精品久久久久影院日本 | 天堂av免费看 | 伊人色综合久久天天 | 日韩高清无线码2023 | 精品国产91亚洲一区二区三区www | 国产午夜三级一区二区三桃花影视 | japanesexxxhd奶水 91在线精品一区二区 | 日韩有码欧美 | 成人精品视频久久久久 | 国产五十路毛片 | 亚洲免费不卡 | 久久免费播放视频 | 日韩城人在线 | 香蕉视频网址 | 激情综合五月天 | 99av在线视频 | 一性一交视频 | 成人在线超碰 | 中文字幕视频观看 | 日韩在线字幕 | 亚洲在线成人精品 | 免费视频成人 | 99久久精品国产系列 | 欧美一级裸体视频 | 欧美精品久久久久久久久老牛影院 | 激情伊人 | 久久久久久久久久久久国产精品 | 欧美日韩电影在线播放 | 99精品偷拍视频一区二区三区 | 国产99久久久国产精品成人免费 | 手机av观看 | 国产精品毛片一区视频播不卡 | 久久9999久久 | 亚洲精选在线观看 | 亚洲,国产成人av | 九色精品免费永久在线 | www.在线观看av | 免费不卡中文字幕视频 | 日韩一区二区在线免费观看 | 国产伦精品一区二区三区高清 | 国内精品二区 | 日韩在线免费视频观看 | 2023年中文无字幕文字 | 国产破处在线视频 | 中文字幕资源网在线观看 | 99热高清| 不卡av在线 | 国内精品视频在线 | 91精品久 | 欧美日韩精品二区第二页 | 91亚洲视频在线观看 | 国产在线精品福利 | 国产原厂视频在线观看 | 夜夜骑首页 | 欧美综合干 | 亚洲精品91天天久久人人 | 欧美国产亚洲精品久久久8v | 久久精品美女视频网站 | 国产精品一二三 | 亚州av成人 | 日本少妇久久久 | 福利区在线观看 | 免费在线播放av电影 | 狠狠狠狠狠狠狠狠 | 伊人六月| 久久久国产一区 | 91精品久久久久久综合乱菊 | 亚洲理论在线 | 亚洲国产精品小视频 | 97看片网 | av片中文字幕 | 国产96在线| 免费黄色小网站 | 99久久夜色精品国产亚洲 | 国产一区二区不卡视频 | 91亚洲精 | 国产精品黑丝在线观看 | 久久精品国产成人 | 成人免费视频在线观看 | 午夜精选视频 | 成人播放器 | 国产精品v欧美精品v日韩 | 99麻豆视频 | 1024手机在线看 | 色黄www小说 | av丝袜在线 | 欧美一级日韩免费不卡 | 综合久久久久久 | 伊人久久精品久久亚洲一区 | 国产精品永久 | 久久久久二区 | av丝袜美腿 | 亚洲国产免费网站 | 欧美乱淫视频 | 日韩欧美一区二区三区视频 | 欧美日韩高清免费 | 在线视频观看成人 | 人人爽夜夜爽 | 国内成人精品2018免费看 | 国产精品不卡一区 | 麻豆免费观看视频 | 国产性xxxx | 国产在线观看免费观看 | 又爽又黄又刺激的视频 | 四虎影院在线观看av | 久久视频国产精品免费视频在线 | 一级黄色片毛片 | 亚洲精品午夜久久久久久久 | www国产亚洲精品久久网站 | 婷婷综合久久 | 久久久久久久久久久久电影 | 日日躁夜夜躁xxxxaaaa | 成人网在线免费视频 | 96亚洲精品久久久蜜桃 | 伊人影院99 | 91精品国产99久久久久 | 综合色综合 | 九九热视频在线播放 | 日韩有码在线播放 | 97人人看 | 在线观看日韩精品视频 | 亚洲综合成人婷婷小说 | 中文字幕在线视频国产 | 亚洲国产高清在线 | 狠狠插天天干 | 久久久毛片| 久久久亚洲网站 | 狠狠干夜夜爱 | 成人久久久精品国产乱码一区二区 | 国产aa免费视频 | 91精品国产91热久久久做人人 | 在线免费观看麻豆视频 | 久久免费视频一区 | 亚洲欧美婷婷六月色综合 | 激情欧美一区二区免费视频 | 久久69av| 啪啪激情网 | 狠狠干狠狠操 | 亚洲精品高清视频在线观看 | 99热最新地址 | 波多野结衣视频一区二区三区 | 99这里只有精品99 | 国产精品理论在线观看 | 日韩精品视频在线免费观看 | 少妇搡bbbb搡bbb搡忠贞 | 99视频在线观看视频 | 黄色网在线免费观看 | 在线观看成人一级片 | 精品视频免费 | 91精品视频免费在线观看 | 三上悠亚一区二区在线观看 | av一级网站 | 成年人免费看片 | 国产亚洲久一区二区 | 久久夜色精品国产欧美乱极品 | 免费黄色在线网站 | 日本性动态图 | 亚洲精品理论 | 国产精品美女久久久久久久久久久 | 日本精品久久久久影院 | av日韩不卡| 性色av免费看 | 婷婷色av| 蜜臀久久99精品久久久久久网站 | a在线免费| 在线电影91 | 欧美精品免费一区二区 | 欧美精品一区二区三区四区在线 | 丝袜av网站 | 黄色免费高清视频 | 日韩欧美视频在线观看免费 | 超碰人人超| 激情综合网五月婷婷 | 日韩一级电影在线观看 | 黄色毛片一级 | 毛片精品免费在线观看 | 91av国产视频| 亚洲一区二区高潮无套美女 | 欧美激情精品久久久久久免费 | 亚洲视频1 | 国产又粗又猛又黄又爽 | 99久久99久久精品 | 国产成人一二片 | 免费在线一区二区三区 | 天天曰夜夜爽 | 欧美嫩草影院 | 日日干天天爽 | 欧美午夜久久 | 欧美国产日韩一区二区三区 | www.伊人网 | 五月激情综合婷婷 | 国产精品久久久亚洲 | 国产成人精品不卡 | 免费黄a大片 | 深夜国产福利 | 中文字幕av免费 | 91porny九色91啦中文 | 国产裸体视频bbbbb | 国产 日韩 欧美 自拍 | 国产拍揄自揄精品视频麻豆 | 久久久久99精品国产片 | 日韩簧片在线观看 | 久操久| 在线精品视频免费播放 | 在线观看av黄色 | 日韩精品视频免费在线观看 | 国产免费黄视频在线观看 | 国产在线欧美日韩 | 最近免费中文视频 | 91日韩精品 | 久草.com| 国产精品久久久久久模特 | 中文字幕免费播放 | 亚洲综合色av| 欧美在线观看禁18 | 久久久久美女 | 丰满少妇在线观看网站 | 亚洲黄网址 | 国产国语在线 | 国产精品12 | 日韩mv欧美mv国产精品 | 美国av片在线观看 | 国产中文字幕视频 | 在线 高清 中文字幕 | 国产精品一区在线 | 狠色在线 | 日韩在线国产精品 | 一区二区在线电影 | 久久福利精品 | 337p西西人体大胆瓣开下部 | 91视视频在线直接观看在线看网页在线看 | 久草香蕉在线视频 | 在线看岛国av | 久久看片网站 | 在线视频观看你懂的 | 丁香综合激情 | 亚洲人成网站精品片在线观看 | 日韩网站免费观看 | 狠狠色丁香婷婷综合最新地址 | 亚洲日本三级 | 日韩电影在线一区二区 | 2021国产视频 | 男女拍拍免费视频 | 日韩va欧美va亚洲va久久 | 精品国产一区二区三区免费 | 久草久草在线 | 欧美怡红院 | 午夜av在线 | 亚洲综合欧美精品电影 | 国产精品美女在线 | 最新国产在线观看 | 摸bbb搡bbb搡bbbb | 国产在线观看黄 | 热re99久久精品国产99热 | 亚洲一区欧美激情 | 国产成人亚洲精品自产在线 | 成人黄色资源 | 91av99| 国产成人av福利 | 午夜在线观看一区 | 中文字幕国语官网在线视频 | 高清免费在线视频 | 国产成人精品一区二区 | 午夜体验区 | 国产精品va| 国产精品专区一 | 成人三级网站在线观看 | 亚洲春色成人 | 久草在在线视频 | 国产在线观看免费av | 久久综合色一综合色88 | 九九热在线观看视频 | 在线观看亚洲精品 | 亚洲精品视频免费看 | 永久免费的av电影 | 96亚洲精品久久久蜜桃 | 97网| 国产一级免费在线观看 | 黄色a大片| 黄色精品一区 | 中文字幕一区二区三区在线播放 | 国产五码一区 | 激情av五月婷婷 | 国产美女精品人人做人人爽 | 精品一区二区在线免费观看 | 国产高清在线免费视频 | 国产精品一区二区吃奶在线观看 | 六月色播 | 最近免费中文字幕mv在线视频3 | 亚洲国产美女精品久久久久∴ | 欧美黄色软件 | 97超碰免费在线 | 99精品视频99| 久久婷婷色综合 | 999久久久免费精品国产 | 精品中文字幕在线观看 | 在线观看激情av | 97成人超碰 | 美女视频又黄又免费 | 特级西西444www高清大视频 | 久久久久久久免费看 | 国产亚洲午夜高清国产拍精品 | 成人影片在线播放 | 在线观看91网站 | 麻花豆传媒一二三产区 | 伊人久久国产 | 亚洲欧美观看 | 久青草影院| 日韩三级一区 | 日韩在线小视频 | 探花视频在线观看+在线播放 | 久久精品视频在线观看 | 国产精品毛片久久久久久 | 夜夜操天天摸 | 中文字幕五区 | 日日干狠狠操 | 欧美一级久久 | 免费观看高清 | 91麻豆看国产在线紧急地址 | 亚洲电影第一页av | wwwwww黄 | 国语精品久久 | 亚洲国产午夜 | 午夜精品久久久久久久久久久久 | 毛片无卡免费无播放器 | 国产不卡视频在线播放 | 久久久亚洲麻豆日韩精品一区三区 | 97在线影视 | 天天干天天操天天入 | 亚洲国产精品va在线看黑人 | 欧美成人日韩 | 五月开心婷婷 | 婷婷色综合 | 中国一级片在线观看 | 国产老熟| 亚洲国产午夜精品 | 香蕉视频在线免费 | 欧美大片在线看免费观看 | 国产精品免费看久久久8精臀av | 日韩av在线高清 | www国产精品com| 精品欧美在线视频 | 91在线观看视频网站 | 操天天操| 九九色视频| 999国产在线 | 免费看的av片 | 色在线中文字幕 | 精品久久久久久久久久久久久久久久 | 久久久久久久影视 | 最近免费中文字幕mv在线视频3 | 国产精品毛片 | www.av免费观看| av大全在线| 久久国产成人午夜av影院潦草 | 九九热有精品 | 天天爱综合 | 在线视频精品 | 亚洲 成人 一区 | 国产v在线观看 | 中文字幕亚洲在线观看 | 色吧av色av| 黄色毛片视频免费 | 一二三区av | 国产精品色婷婷视频 | 九九国产精品视频 | av 一区二区三区 | 国产精品k频道 | 六月色| 久久人视频 | 久久精品99久久久久久 | 草久中文字幕 | 伊人狠狠色 | 久久在线播放 | 国产精品视频永久免费播放 | 少妇精品久久久一区二区免费 | 91午夜精品 | 97超碰超碰久久福利超碰 | 亚洲精品在线观看不卡 | 天天五月天色 | 久久久穴 | 欧美激情精品久久久久久免费 | 欧美日韩视频 | 粉嫩av一区二区三区入口 | 亚洲综合黄色 | 国产视频午夜 | 91中文字幕一区 | 久久99国产精品久久99 | 久久欧洲视频 | 999久久久久久久久6666 | 国产美女网站在线观看 | 色偷偷人人澡久久超碰69 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 青青色影院 | 超碰97.com | 色网站免费在线观看 | 不卡av在线免费观看 | 成人观看 | 亚洲在线精品视频 | 日韩一区在线播放 | 日韩在线观看一区二区 | 色婷婷丁香 | 亚洲成色 | 亚州精品一二三区 | 91丨精品丨蝌蚪丨白丝jk | 黄色片网站av | 丝袜美女视频网站 | 日韩欧三级 | 中文字幕在线专区 | 国产一区在线精品 | 国产精品久久久久久一二三四五 | 久久福利电影 | 天天拍天天色 | 国产91免费看 | av在线观| 国产一区在线精品 | 在线看片中文字幕 | 国产成人精品一区二区三区网站观看 | 一区二区精 | 欧美激情视频一二三区 | 99在线精品视频在线观看 | 色黄www小说 | 日韩在线 | 日韩免费 | 久久免费视频7 | 在线观看免费日韩 | 国产精品一区二区三区免费视频 | 日本bbbb摸bbbb| 日韩理论在线 | 六月丁香激情综合色啪小说 | 国产又粗又猛又黄又爽的视频 | 99r精品视频在线观看 | 国产专区欧美专区 | 就要色综合 | 九九免费视频 | 日本性xxxxx 亚洲精品午夜久久久 | 色av男人的天堂免费在线 | 久久黄页| 极品嫩模被强到高潮呻吟91 | 丁香久久久 | 日韩久久久久久久久久 | 国产精品第一视频 | 亚洲综合网 | 国产中文字幕在线观看 | 精品一区二区久久久久久久网站 | 久久久精品日本 | 日韩欧美一区二区三区在线 | 亚洲精品国精品久久99热 | 91在线精品秘密一区二区 | 国产精品国产三级国产aⅴ入口 | 激情视频一区二区三区 | 久久视频在线 | 亚洲片在线观看 | 麻豆免费视频 | 色综合久久久久久久久五月 | 视频在线观看一区 | 日韩午夜精品 | 国产精品亚州 | www狠狠| 97干com | 黄色网址av | 国产在线视频资源 | 午夜三级在线 | 成年人视频在线观看免费 | 日韩在线观看电影 | 国产日韩欧美在线看 | 成人18视频| 亚洲精品一区二区三区高潮 | 国产高清专区 | 美女久久久 | 国产成人香蕉 | 国产91精品久久久久 | 日精品 | 国产在线观看你懂的 | 天天爽夜夜爽精品视频婷婷 | 九九视频这里只有精品 | 97超碰人人 | 正在播放国产一区 | 国产在线精品一区二区三区 | 99免费在线视频 | 国产成人av在线影院 | 国产精选在线观看 | 成人久久18免费网站图片 | 色综合天天做天天爱 | 国产在线精品一区二区三区 | 久久国产成人午夜av影院宅 | 国产成人精品一区二区三区福利 | 91网页版免费观看 | 久久精品久久99精品久久 | 婷婷成人在线 | 99色亚洲 | 日日干干| 欧美一区二区三区在线看 | 日日干夜夜干 | 91精品国产92久久久久 | 在线免费观看视频一区二区三区 | 在线中文字幕av观看 | 亚洲精品456在线播放 | 五月天视频网站 | 亚洲女人天堂成人av在线 | 欧美日韩国产综合一区二区 | 国产精品美女久久久久aⅴ 干干夜夜 | 久草网首页 | 久久婷婷视频 | 中文字幕 国产视频 | 免费av观看| 久久久精品电影 | 国产高清日韩欧美 | 8x成人在线| 美女视频黄免费 | 精品久久久久久久 | 伊人丁香 | 免费观看一级特黄欧美大片 | 日日夜夜国产 | 日本久久99 | 丁香婷婷激情国产高清秒播 | 日韩国产欧美在线播放 | 91日韩在线视频 | 精品国产黄色片 | 亚洲午夜精品久久久久久久久久久久 | 欧美午夜理伦三级在线观看 | 久久久久欧美精品999 | 欧美国产91 | 亚洲成色 | 久久成人在线视频 | 精品专区一区二区 | 西西www444| 97精品国产97久久久久久久久久久久 | 国产精品永久在线 | 亚洲国产日韩精品 | 国产区在线看 | 91精品国自产在线 | 成人免费观看a | 黄色录像av | 成人在线免费视频观看 | 国产91精品看黄网站在线观看动漫 | 四虎影视精品成人 | 毛片基地黄久久久久久天堂 | 欧美一区二区在线 | 国产理论片在线观看 | 在线va视频 | 久久日韩精品 | av成人在线看 | 国产日韩视频在线观看 | 天天爽天天做 | 成人免费网站视频 | 国产精品久久久久久一区二区三区 | 国产精品久久久久久久久久 | 天天爽夜夜爽精品视频婷婷 | 久久精品超碰 | 日日干网址 | 又污又黄的网站 | 久久久久久久久久影视 | 91麻豆国产 | 国产精品男女 | 精品无人国产偷自产在线 | 91黄色小视频 | 日韩av不卡播放 | 中文字幕专区高清在线观看 | 制服丝袜亚洲 | 91禁在线看 | 日日夜夜天天射 | 中文字幕国产在线 | 激情网五月婷婷 | 久久免费美女视频 | 韩国一区视频 | 综合在线观看色 | 成人国产精品入口 | 丁香 婷婷 激情 | 五月天综合激情 | 欧美另类人妖 | 在线国产日本 | 日韩av在线不卡 | 国产精品免费久久久久影院仙踪林 | 免费情缘| 成片视频免费观看 | 久久情爱| 国产黄色特级片 | 亚洲v精品 | 久久天天躁狠狠躁亚洲综合公司 | 碰超在线| 亚洲更新最快 | 91九色老 | 奇米影视999| 日韩中文字幕视频在线观看 | 中文字幕网站 | 中文字幕久久精品亚洲乱码 | 香蕉成人在线视频 | av在线之家电影网站 | 在线a人片免费观看视频 | 亚洲精品成人 | 99精品视频在线看 | 丁香国产视频 | 中文字幕人成一区 | av看片网 | 97超碰人人看 | 黄色大片网 | 欧美一级久久久 | 成人播放器 | 亚洲激情一区二区三区 | av成人在线电影 | 女人魂免费观看 | 免费色av | 91经典在线 | 成人av在线网址 | 国产高清视频免费在线观看 | 亚洲欧美日韩不卡 | 最新99热 | 精品一区二区电影 | 欧美另类xxx | 欧美日韩国产一区二区三区在线观看 | 日韩电影精品 | 99国产精品视频免费观看一公开 | 日韩激情av在线 | 婷婷免费在线视频 | 免费在线黄 | 在线观看中文字幕一区二区 | www.久久爱.cn | 久久精品官网 | 欧美激情综合色综合啪啪五月 | 在线精品在线 | 国产精品一区二区美女视频免费看 | 亚洲国产精品视频 | a v在线视频 | 不卡av电影在线观看 | 欧美国产一区二区 | 国产亚洲在线视频 | 免费av网站在线看 | 亚洲精品免费在线播放 | 成人av电影在线播放 | 国产精品福利久久久 | 综合在线观看 | 国产精品福利av | 午夜在线日韩 | 国产黄在线播放 | 欧美了一区在线观看 | 欧洲性视频 | 91av视频导航 | 中文字幕在线资源 | 成人va在线观看 | 一区二区中文字幕在线观看 | 久久免费视频在线观看 | 91久久久久久久一区二区 | 欧美视频国产视频 | 国产免费久久av | 色综合久久中文综合久久牛 | 99中文字幕| 日韩精品视 | 97成人精品视频在线观看 | 97超碰人人网 | 国内毛片毛片 | 亚洲国产mv | 亚洲视频 中文字幕 | 免费在线观看日韩欧美 | 免费合欢视频成人app | 免费看一及片 | 国产一区二区播放 | 99久久精品免费看国产四区 | 精品1区二区| 久久久免费在线观看 | 久久国产一区二区三区 | 精品久久一区二区三区 | 91久久一区二区 | 亚洲欧美视频在线 | 五月婷婷操 | 少妇自拍av| adn—256中文在线观看 | 2023av在线| 视频在线一区 | 狠狠婷婷 | 亚洲 中文 在线 精品 | 在线免费日韩 | 亚洲理论在线观看 | 久久人人爽视频 | av免费看电影 | 日韩欧美一区二区三区免费观看 | 成年人app网址 | 亚洲视频 视频在线 | 亚洲a在线观看 | 亚洲久在线 | 四虎国产 | 综合在线观看色 | 日韩欧美一区二区在线观看 | 99在线观看视频 | 9999免费视频 | 日本三级人妇 | 久久国产成人午夜av影院潦草 | 久久这里有精品 | 日韩午夜精品 | 美女中文字幕 | 五月天久久| 国产高清视频免费在线观看 | 国产成人精品av在线观 | 国产 中文 日韩 欧美 | 天天射天天射天天 | 9免费视频 | 在线视频观看亚洲 | 人人爱天天操 | 国内精品久久久久久久久久久久 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 国产日韩欧美在线看 | 狠狠干综合 | av午夜电影 | 波多野结衣在线视频一区 | 欧美日韩国产成人 | 国产精品成人自产拍在线观看 | 免费成人在线电影 | 国产精品99久久久久久有的能看 | 婷久久 | 亚洲欧美成人综合 | 伊人www22综合色 | 久精品视频在线 | 天天草天天色 | 欧美视频二区 | 国产一级高清视频 | 国产精品色在线 | 久草在线99| 97高清视频 | 中文字幕一区二区三区四区 | 免费看的黄色小视频 | 91久久丝袜国产露脸动漫 | 久久国产精品久久久久 | 久久久久久久久久久久久久免费看 | 日本激情中文字幕 | 国产精品对白一区二区三区 | 97色婷婷人人爽人人 | 国产特级毛片aaaaaaa高清 | 国产精品久久久毛片 | 久草国产视频 | 成人在线观看免费 | 亚洲一区二区三区91 | 久精品视频在线观看 | 精品视频在线免费观看 | av不卡在线看 | 色婷婷精品大在线视频 | www中文在线 | 欧美亚洲成人免费 | 国产看片免费 | 中文字幕在线资源 | 国产精品理论片在线播放 | av电影在线免费 | 正在播放 久久 | 免费看的黄色录像 | 欧美人体xx | 天天操夜夜拍 | 三上悠亚一区二区在线观看 | 99精品在线视频播放 | 99热国产在线中文 | 韩国一区二区av | 亚洲国产99 | 久久久久免费电影 | 中文国产在线观看 | 国产在线观看91 | 亚洲一区视频在线播放 | 最新国产精品亚洲 | 欧美另类xxxxx | 久久久久电影网站 | 国产一区欧美日韩 | 久久久久成人精品 | 国产 日韩 欧美 自拍 | 国内外激情视频 | 亚洲国产中文字幕在线观看 | 色婷婷88av视频一二三区 | 久久久午夜电影 | 日韩理论电影网 | 久久婷婷精品 | 精品久久久免费视频 | 色妞久久福利网 | 免费看一及片 | 伊人永久在线 | 在线免费观看av网站 | 精品免费国产一区二区三区四区 | 久久天天草| 欧美精品在线观看免费 | 91av社区 | 91看片黄色 | 在线视频 国产 日韩 | 久久久精品久久 | 日本黄色大片免费看 | 欧美日韩性视频在线 | 久久国产精品久久久久 | 91激情视频在线播放 | 久久精品79国产精品 | 日本成人中文字幕在线观看 | 国产亚洲婷婷免费 | 欧美日韩另类在线 | 久久精品伊人 | 国产97视频 | 国产丝袜高跟 | 欧美va在线观看 | 亚洲网站在线看 | 久久在线影院 | 69久久久 | 日韩av视屏在线观看 | 国产二区精品 | 亚洲免费在线视频 | 91在线精品秘密一区二区 | 欧美污网站 | 麻豆网站免费观看 | 成人免费视频播放 | 亚洲国产精品电影 | 久青草视频在线观看 | 精品国产亚洲在线 | 美女网站一区 | 美女久久 | 中文字幕一区二区三区乱码不卡 | 午夜精品一二三区 | 国产精品99免视看9 国产精品毛片一区视频 | 国产成人精品日本亚洲999 | 国产精品va在线 | 欧美精品乱码久久久久 | 91网站免费观看 |