亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python網絡編程基于多線程實現多用戶全雙工聊天功能示例

發布時間:2020-10-12 20:19:22 來源:腳本之家 閱讀:189 作者:jiange_zh 欄目:開發技術

本文實例講述了Python網絡編程基于多線程實現多用戶全雙工聊天功能。分享給大家供大家參考,具體如下:

在前面一篇《Python網絡編程使用select實現socket全雙工異步通信功能》中,我們實現了1對1的異步通信,在文章結尾,給出了多對多通信的思路。

既然說了,咱就動手試一試,本次用的是多線程來實現,正好練練手~

首先講一下思路:

我們將服務器做為中轉站來處理信息,一方面與客戶端互動,另一方面進行消息轉發。

大體思路確定下來后,需要確定一些通信規則:

1. 客戶端與服務器建立連接后,需要輸入用戶名登入,若用戶名已存在,將reuse反饋給用戶,用戶輸出錯誤信息,退出

2. 用戶輸入正確的用戶名后,即可進行通信了。如果未選擇通信對象,則服務器會反饋信息,提示用戶選擇通信對象

3. 選擇通信對象的方法為,輸入to:username,如果所選擇的對象不存在,反饋錯誤信息,重新輸入

4.當正確選擇通信對象后,雙方建立連接,通過服務器中轉信息進行通信

5.在通信中,若發送‘quit',則結束發送消息的線程,并指示服務器該用戶準備登出,服務器刪除該用戶后,反饋消息給用戶,用戶結束接收消息的線程并退出

6.如果A正在與C通信,此時B向A發送信息,則A的通信窗口變為與B的通信窗口,即接收到B消息后,A發出的消息不再是給C,而是默認給B

實現代碼:

#!/usr/bin/python
'test TCP server'
from socket import *
from time import ctime
import threading  #多線程模塊
import re   #正則表達式模塊
HOST = ''
PORT = 21567
BUFSIZ = 1024
ADDR = (HOST, PORT)
def Deal(sock, user):
  while True:
    data = sock.recv(BUFSIZ)  #接收用戶的數據
    if data == 'quit':  #用戶退出
      del clients[user]
      sock.send(data)
      sock.close()
      print '%s logout' %user
      break
    elif re.match('to:.+', data) is not None:  #選擇通信對象
      data = data[3:]
      if clients.has_key(data):
        chatwith[sock] = clients[data]
        chatwith[clients[data]] = sock
      else:
        sock.send('the user %s is not exist' %data)
    else:
      if chatwith.has_key(sock):  #進行通信
        chatwith[sock].send("[%s] %s: %s" %(ctime(), user, data))
      else:
        sock.send('Please input the user who you want to chat with')
tcpSerSock = socket(AF_INET, SOCK_STREAM)
tcpSerSock.bind(ADDR)
tcpSerSock.listen(5)
clients = {}  #提供 用戶名->socket 映射
chatwith = {}  #提供通信雙方映射
while True:
  print 'waiting for connection...'
  tcpCliSock, addr = tcpSerSock.accept()
  print '...connected from:',addr
  username = tcpCliSock.recv(BUFSIZ)  #接收用戶名
  print 'The username is:',username
  if clients.has_key(username):  #查找用戶名
    tcpCliSock.send("Reuse")  #用戶名已存在
    tcpCliSock.close()
  else:
    tcpCliSock.send("Welcome!")  #登入成功
    clients[username] = tcpCliSock
    chat = threading.Thread(target = Deal, args = (tcpCliSock,username))  #創建新線程進行處理
    chat.start()  #啟動線程
tcpSerSock.close()

#!/usr/bin/python
'test tcp client'
from socket import *
import threading
HOST = 'localhost'
PORT = 21567
BUFSIZ = 1024
ADDR = (HOST, PORT)
threads = []
def Send(sock, test):  #發送消息
  while True:
    data = raw_input('>')
    tcpCliSock.send(data)
    if data == 'quit':
      break
def Recv(sock, test):   #接收消息
  while True:
    data = tcpCliSock.recv(BUFSIZ)
    if data == 'quit':
      sock.close()   #退出時關閉socket
      break
    print data
tcpCliSock = socket(AF_INET, SOCK_STREAM)
tcpCliSock.connect(ADDR)
print 'Please input your username:',
username = raw_input()
tcpCliSock.send(username)
data = tcpCliSock.recv(BUFSIZ)
if data == 'Reuse':
  print 'The username has been used!'
else:
  print 'Welcome!'
  chat = threading.Thread(target = Send, args = (tcpCliSock,None))  #創建發送信息線程
  threads.append(chat)
  chat = threading.Thread(target = Recv, args = (tcpCliSock,None))  #創建接收信息線程
  threads.append(chat)
  for i in range(len(threads)):  #啟動線程
    threads[i].start()
  threads[0].join()  #在我們的設計中,send線程必然先于recv線程結束,所以此處只需要調用send的join,等待recv線程的結束。

當然,本程序還有許多不足之處,比如通信雙方中A退出時,另一方B的通信列表中仍然又A,此時如果B再向已經登出的B發送消息,就會出錯。博主比較懶,就不修復這個bug啦~

更多關于Python相關內容可查看本站專題:《Python Socket編程技巧總結》、《Python數據結構與算法教程》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》

希望本文所述對大家Python程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新河县| 和平区| 张掖市| 泸溪县| 奇台县| 彭阳县| 隆子县| 赤水市| 崇左市| 宁安市| 苗栗县| 东丰县| 安岳县| 凌海市| 息烽县| 伊吾县| 怀来县| 龙泉市| 鄂州市| 蓝田县| 青海省| 林口县| 如东县| 进贤县| 新蔡县| 江孜县| 南华县| 普兰县| 罗江县| 新田县| 新安县| 辽阳市| 镇坪县| 黎平县| 明溪县| 穆棱市| 德阳市| 日照市| 乌兰浩特市| 泸水县| 女性|