Python實現(xiàn)TCP通信的示例代碼
使用socket實現(xiàn)tcp通信,需導(dǎo)入socket模塊
1、服務(wù)端
主要步驟:
(1)創(chuàng)建socket:socket.socket(family=AF_INET, type=SOCK_STREAM, proto=0, fileno=None)
family:AF_INET , AF_INET6, AF_UNIX, AF_CAN, AF_PACKET, AF_RDS
type:SOCK_STREAM , SOCK_DGRAM, SOCK_RAW,或者其他SOCK_*
proto:一般使用默認值0
fileno:一般使用默認值
(2)綁定IP和端口號:socket.bind(address)
address:使用(host,port)元組即可
(3)監(jiān)聽:socket.listen([backlog])
backlog:就理解為最大連接數(shù)
(4)接受連接:socket.accept()
返回(conn,address)元組,分別是已連接客戶端的socket對象和地址
(5)發(fā)送/接受數(shù)據(jù):socket.recv(bufsize[, flags])/socket.send(bytes[, flags])
bufsize:接收的數(shù)據(jù)最大字節(jié)數(shù)
bytes:需要發(fā)送的數(shù)據(jù)字節(jié)數(shù)
(6)關(guān)閉連接:socket.close()
#!/usr/bin/python
# -*- coding: UTF-8 -*-
# 文件名:tcpserver.py
import socket
import time
MaxBytes=1024*1024
server = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
server.settimeout(60)
host = '127.0.0.1'
#host = socket.gethostname()
port = 11223
server.bind((host, port)) # 綁定端口
server.listen(1) # 監(jiān)聽
try:
client,addr = server.accept() # 等待客戶端連接
print(addr," 連接上了")
while True:
data = client.recv(MaxBytes)
if not data:
print('數(shù)據(jù)為空,我要退出了')
break
localTime = time.asctime( time.localtime(time.time()))
print(localTime,' 接收到數(shù)據(jù)字節(jié)數(shù):',len(data))
print(data.decode())
client.send(data)
except BaseException as e:
print("出現(xiàn)異常:")
print(repr(e))
finally:
server.close() # 關(guān)閉連接
print("我已經(jīng)退出了,后會無期")
這個實例沒有創(chuàng)建其他線程,也只接收一個客戶端的連接;為了能手動結(jié)束或自動結(jié)束accept和recv的阻塞,設(shè)置了超時60秒,并將主體部分放入到try語句中;將socket的關(guān)閉放到finally塊中,可以防止程序異常退出,而導(dǎo)致沒有調(diào)用close函數(shù)。
2、客戶端
主要步驟:
(1)創(chuàng)建socket:socket.socket(family=AF_INET, type=SOCK_STREAM, proto=0, fileno=None)
(2)連接:socket.connect(address)
address:使用(host,port)元組即可
(3)發(fā)送/接受數(shù)據(jù):socket.recv(bufsize[, flags])/socket.send(bytes[, flags])
(4)關(guān)閉連接:socket.close()
#!/usr/bin/python
# -*- coding: UTF-8 -*-
# 文件名:tcpclient.py
import socket
import time
MaxBytes=1024*1024
host ='127.0.0.1'
port = 11223
client = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
client.settimeout(30)
client.connect((host,port))
while True:
inputData=input(); #等待輸入數(shù)據(jù)
if(inputData=="quit"):
print("我要退出了,再見")
break
sendBytes = client.send(inputData.encode())
if sendBytes<=0:
break;
recvData = client.recv(MaxBytes)
if not recvData:
print('接收數(shù)據(jù)為空,我要退出了')
break
localTime = time.asctime( time.localtime(time.time()))
print(localTime, ' 接收到數(shù)據(jù)字節(jié)數(shù):',len(recvData))
print(recvData.decode())
client.close()
print("我已經(jīng)退出了,后會無期")
以上客戶端連接成功后等待用戶輸入,然后將輸入信息發(fā)送到服務(wù)端,服務(wù)端將數(shù)據(jù)原樣返回給客戶端,如果客戶端輸入quit就會跳出循環(huán)并關(guān)閉socket,這時服務(wù)端recv會返回空從而跳出循環(huán)并關(guān)閉socket。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python網(wǎng)絡(luò)編程之HTTP協(xié)議的python應(yīng)用
HTTP是在網(wǎng)絡(luò)上傳輸HTML的協(xié)議,用于瀏覽器和服務(wù)器的通信,這篇文章主要介紹了Python網(wǎng)絡(luò)編程之HTTP協(xié)議的python應(yīng)用,需要的朋友可以參考下2022-11-11
Python+Selenium+Pytesseract實現(xiàn)圖片驗證碼識別
這篇文章主要介紹了利用Python+Selenium+Pytesseract實現(xiàn)圖片驗證碼識別,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-01-01
pytorch 數(shù)據(jù)處理:定義自己的數(shù)據(jù)集合實例
今天小編就為大家分享一篇pytorch 數(shù)據(jù)處理:定義自己的數(shù)據(jù)集合實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12
網(wǎng)站滲透常用Python小腳本查詢同ip網(wǎng)站
這篇文章主要介紹了網(wǎng)站滲透常用Python小腳本查詢同ip網(wǎng)站,需要的朋友可以參考下2017-05-05

