如何使用socket發(fā)送信息
tcp協(xié)議, 使用SOCK_DGRAM
udp協(xié)議, 使用SOCK_STREAM
# 導(dǎo)入socket包
from socket import *
# 得到一個(gè)socket對象(參數(shù)都是固定的, tcp/udp協(xié)議見上文)
udpSocket = socket(AF_INET, SOCK_DGRAM)
#如果是python3, sendto的第一個(gè)參數(shù)要加個(gè)b, 后面的元組第一個(gè)元素是IP地址(加雙引號),第二個(gè)元素是端口號
udpSocket.sendto("haha", ("192.168.1.101", 8080))
如果是python3, 在第一個(gè)參數(shù)前面加"b"
udpSocket.sendto(b"haha", ("192.168.1.101", 8080))
如何綁定端口
一般來說, 發(fā)送方無需綁定端口, 但是接收方一定要綁定端口
綁定端口的語法: ** socket對象.bind(("IP地址", 端口號)) **
from socket import *
udpSocket = socket(AF_INET, SOCK_DGRAM)
#綁定的地址端口, 如果地址為空, 那么這臺(tái)服務(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é)的信息, 代碼會(huì)在此處堵塞, 直到接收到信息
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ù)(是個(gè)元組,含有接收信息和發(fā)送方地址)
recvData[0].decode("gb2312")
或者
a,b = recvData
a.decode("gb2312")