python3 - 基于threading模块下Thread,实现多线程TCP套接字通信

服务器

import socket
from threading import Thread
import struct, json

IP = '127.0.0.1'
PORT = 8080
ADD = (IP, PORT)

server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind(ADD)
server.listen(5)


def task(conn):
    '''
    在子线程内,实现对应客户端等待输入和数据处理
    :param conn:
    :return:
    '''
    while True:
        try:
            b_header = conn.recv(struct.unpack('i', conn.recv(4))[0])
            header = json.loads(b_header.decode('utf-8'))
            user = header['user']
            msg = header['msg']
            print('%s : %s' % (user, msg))
        except ConnectionResetError:
            break
        except struct.error:
            break


if __name__ == '__main__':
    # 等待建立链接,并且执行线程
    while True:
        conn, c_add = server.accept()
        t = Thread(target=task, args=(conn,))
        t.start()

>>>client_1 : nihao
>>>client_2 : nihao
>>>client_1 : 你好
>>>client_3 : hello
 


客户端 1/2/3/4……

import socket,struct,json

IP = '127.0.0.1'
PORT = 8080
S_ADD = (IP,PORT)

client = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
client.connect(S_ADD)


while True:
    msg = input('请输入(q退出)>>>').strip()
    if msg == 'q':
        break
    header = {
        'user': 'client_1',  # 对应修改
        'msg': msg
    }
    j_header = json.dumps(header)
    b_header = j_header.encode('utf-8')
    s_header = struct.pack('i',len(b_header))

    client.send(s_header)
    client.send(b_header)

>>>请输入(q退出)>>>nihao
>>>请输入(q退出)>>>


注:

1.可以同一个py文件多次执行,作为多进程进行连接。

2.未设置连接数限制,即可以无限建立连接。限制方式:线程池

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
多线程TCP双向通信Python是指使用Python编写程序,通过Socket套接字实现多个客户端与服务端之间的双向通信,并且使用多线程技术实现同时连接多个客户端的程序。具体实现过程如下: 1. 服务端创建一个Socket对象,绑定IP地址和端口号,并监听客户端的连接请求。 2. 客户端创建一个Socket对象,连接服务端的IP地址和端口号。 3. 服务端接收到客户端的连接请求后,创建一个新的线程处理该客户端的请求。 4. 客户端向服务端发送数据,服务端接收到数据后进行处理,并向客户端发送响应数据。 5. 客户端接收到服务端的响应数据后进行处理。 下面是一个简单的多线程TCP双向通信Python的示例代码: ```python # 服务端代码 import socket import threading def handle_client(client_socket, client_address): while True: data = client_socket.recv(1024) if not data: break print("Received data from {}: {}".format(client_address, data.decode())) client_socket.send("Hello, client!".encode()) client_socket.close() def main(): server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) server_socket.bind(('127.0.0.1', 8888)) server_socket.listen(5) print("Server is listening on {}:{}".format('127.0.0.1', 8888)) while True: client_socket, client_address = server_socket.accept() print("Accepted connection from {}:{}".format(client_address[0], client_address[1])) client_thread = threading.Thread(target=handle_client, args=(client_socket, client_address)) client_thread.start() if __name__ == '__main__': main() # 客户端代码 import socket def main(): client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) client_socket.connect(('127.0.0.1', 8888)) while True: data = input("Please input data to send to server: ") client_socket.send(data.encode()) response = client_socket.recv(1024) print("Received response from server: {}".format(response.decode())) if __name__ == '__main__': main() ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值