python如何使用socket實現(xiàn)udp協(xié)議

如何使用socket發(fā)送信息

tcp協(xié)議, 使用SOCK_DGRAM
udp協(xié)議, 使用SOCK_STREAM

# 導(dǎo)入socket包
from socket import *
# 得到一個socket對象(參數(shù)都是固定的, tcp/udp協(xié)議見上文)
udpSocket = socket(AF_INET, SOCK_DGRAM)
#如果是python3, sendto的第一個參數(shù)要加個b, 后面的元組第一個元素是IP地址(加雙引號),第二個元素是端口號
udpSocket.sendto("haha", ("192.168.1.101", 8080))

如果是python3, 在第一個參數(shù)前面加"b"

udpSocket.sendto(b"haha", ("192.168.1.101", 8080))


如何綁定端口

一般來說, 發(fā)送方無需綁定端口, 但是接收方一定要綁定端口
綁定端口的語法: ** socket對象.bind(("IP地址", 端口號)) **

from socket import *

udpSocket = socket(AF_INET, SOCK_DGRAM)
#綁定的地址端口, 如果地址為空, 那么這臺服務(wù)器上的所有地址的7788端口都被綁定
bindAddr = ("", 7788)
#綁定端口
udpSocket.bind(bindAddr)

udpSocket.sendto("haha", ("192.168.1.101", 8080))


如何接收信息

語法: ** 接收數(shù)據(jù)變量 = socket對象.recvfrom(接受數(shù)據(jù)的大小限制) **
得到的數(shù)據(jù)打印出來的格式是: ** (接收的信息,(發(fā)送方的IP, 發(fā)送方的端口)) **

from socket import *

udpSocket = socket(AF_INET, SOCK_DGRAM)

bindAddr = ("", 7788)

udpSocket.bind(bindAddr)
#一次接收最多1024字節(jié)的信息, 代碼會在此處堵塞, 直到接收到信息
recvData = udpSocket.recvfrom(1024)

print(recvData)

打印出來的消息是這樣的:

接收信息打印結(jié)果


<h3>python3存在的問題</h3>

python3中的sendto方法,發(fā)送的信息要求是字節(jié)類型
所以要把要發(fā)送的字符串轉(zhuǎn)化為要求的格式:

#sendData是要發(fā)送的信息字符串,將其轉(zhuǎn)化為要求的格式
sendData.encode("utf-8")

如果編碼要求是其他格式,可以把utf-8改掉,比如改成gb2312等

如果接收到了信息,但是信息是以編碼的形式存在,那么需要解碼, 解碼使用decode
recvData是接收的數(shù)據(jù)(是個元組,含有接收信息和發(fā)送方地址)
recvData[0].decode("gb2312")
或者
a,b = recvData
a.decode("gb2312")

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容