47 lines
1.8 KiB
Python
47 lines
1.8 KiB
Python
|
import json
|
||
|
import multiprocessing
|
||
|
from multiprocessing.connection import Listener
|
||
|
import threading
|
||
|
|
||
|
|
||
|
class ProcessServer:
|
||
|
def __init__(self):
|
||
|
self.Process_port = 12321
|
||
|
self.Process_server = 'localhost'
|
||
|
self.Process_server_listener = Listener((self.Process_server, self.Process_port))
|
||
|
self.Process_client_link_dick = {}
|
||
|
Process_client_link_Thread = threading.Thread(target=self.Process_client_link)
|
||
|
Process_client_link_Thread.start()
|
||
|
|
||
|
def Process_client_link(self):
|
||
|
while True:
|
||
|
client_connect = self.Process_server_listener.accept()
|
||
|
client_Thread_recv = threading.Thread(target=self.Process_client_recv, args=(client_connect,))
|
||
|
client_Thread_recv.start()
|
||
|
|
||
|
def Process_client_recv(self, client_Thread_recv):
|
||
|
while True:
|
||
|
data_json = client_Thread_recv.recv()
|
||
|
data = json.loads(data_json)
|
||
|
if data['target'] == 'Server':
|
||
|
if data['function'] == 'Name':
|
||
|
self.Process_client_link_dick[data['content']] = client_Thread_recv
|
||
|
else:
|
||
|
self.Process_client_pick(data)
|
||
|
|
||
|
def Process_client_send(self, target, function, content):
|
||
|
connect = self.Process_client_link_dick[target]
|
||
|
data = {"target": target, "function": function, "content": content}
|
||
|
data_json = json.dumps(data)
|
||
|
connect.send(data_json)
|
||
|
|
||
|
def Process_client_pick(self, data):
|
||
|
if data['target'] == 'ALL':
|
||
|
for value in self.Process_client_link_dick.values():
|
||
|
data_json = json.dumps(data)
|
||
|
value.send(data_json)
|
||
|
else:
|
||
|
if data['target'] in self.Process_client_link_dick.keys():
|
||
|
data_json = json.dumps(data)
|
||
|
self.Process_client_link_dick[data['target']].send(data_json)
|