does it work
This commit is contained in:
22
clientgui.py
22
clientgui.py
@@ -14,24 +14,32 @@ class MyFrame(wx.Frame):
|
|||||||
panel.SetSizer(my_sizer)
|
panel.SetSizer(my_sizer)
|
||||||
self.host = "lukesau.com"
|
self.host = "lukesau.com"
|
||||||
self.port = 5000 # socket server port number
|
self.port = 5000 # socket server port number
|
||||||
|
self.header_size = 1024
|
||||||
|
self.format = "utf-8"
|
||||||
|
self.disconnect_message = "!DISCONNECT"
|
||||||
self.Show()
|
self.Show()
|
||||||
|
self.client_socket = socket.socket()
|
||||||
|
self.client_socket.connect((self.host, self.port)) # connect to the server
|
||||||
|
|
||||||
def on_press(self, event):
|
def on_press(self, event):
|
||||||
message = self.text_ctrl.GetValue()
|
message = self.text_ctrl.GetValue()
|
||||||
if not message:
|
if not message:
|
||||||
print("You didn't enter anything!")
|
print("You didn't enter anything!")
|
||||||
else:
|
else:
|
||||||
client_socket = socket.socket() # instantiate
|
self.send(message)
|
||||||
client_socket.connect((self.host, self.port)) # connect to the server
|
|
||||||
client_socket.send(message.encode()) # send message
|
|
||||||
data = client_socket.recv(1024).decode() # receive response
|
|
||||||
print('Received from server: ' + data) # show in terminal
|
|
||||||
self.text_ctrl.SetValue("")
|
self.text_ctrl.SetValue("")
|
||||||
client_socket.close()
|
|
||||||
def sync_with_server(self):
|
def sync_with_server(self):
|
||||||
client_socket = socket.socket() # instantiate
|
client_socket = socket.socket() # instantiate
|
||||||
client_socket.connect((self.host, self.port)) # connect to the server
|
client_socket.connect((self.host, self.port)) # connect to the server
|
||||||
|
def send(self, msg):
|
||||||
|
message = msg.encode(self.format)
|
||||||
|
msg_length = len(message)
|
||||||
|
print(msg_length)
|
||||||
|
send_length = str(msg_length).encode(self.format)
|
||||||
|
send_length += b' ' * (self.header_size - len(send_length))
|
||||||
|
self.client_socket.send(send_length)
|
||||||
|
self.client_socket.send(message)
|
||||||
|
print("done sending")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -7,27 +7,32 @@ class ServerVCKO:
|
|||||||
self.host = socket.gethostname()
|
self.host = socket.gethostname()
|
||||||
self.port = 5000
|
self.port = 5000
|
||||||
self.server_socket = socket.socket()
|
self.server_socket = socket.socket()
|
||||||
self.server_socket.bind((host, port))
|
self.server_socket.bind((self.host, self.port))
|
||||||
self.header_size = 1024
|
self.header_size = 1024
|
||||||
self.format = "utf-8"
|
self.format = "utf-8"
|
||||||
|
self.disconnect_message = "!DISCONNECT"
|
||||||
|
|
||||||
def handle_client(conn, addr):
|
def handle_client(conn, addr):
|
||||||
print("Connection from: " + str(address))
|
print("Connection from: " + str(address))
|
||||||
connected = True
|
connected = True
|
||||||
while connected:
|
while connected:
|
||||||
msg_length = conn.recv(self.header_size).decode(self.format)
|
msg_length = conn.recv(self.header_size).decode(self.format)
|
||||||
msg_length = int(msg_length)
|
if msg_length:
|
||||||
msg = conn.recv(msg_length).decode(self.format)
|
msg_length = int(msg_length)
|
||||||
print(f"[{addr
|
msg = conn.recv(msg_length).decode(self.format)
|
||||||
|
if msg == disconnect_message:
|
||||||
|
connected = False
|
||||||
|
print(f"[{addr}] {msg}")
|
||||||
|
conn.close()
|
||||||
def start(self):
|
def start(self):
|
||||||
self.server.listen()
|
self.server_socket.listen()
|
||||||
|
print(f"server is listening on {socket.gethostbyname(self.host)}")
|
||||||
while True:
|
while True:
|
||||||
conn, address = server_socket.accept()
|
conn, address = self.server_socket.accept()
|
||||||
thread = threading.Thread(target = handle_client, args = (conn, addr))
|
thread = threading.Thread(target = self.handle_client, args = (conn, address))
|
||||||
thread.start
|
thread.start
|
||||||
print(f"Active threads: {threading.activeCount() - 1}")
|
print(f"Active threads: {threading.active_count() - 1}")
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
print("server starting")
|
print("server starting")
|
||||||
server = ServerVCKO()
|
server = ServerVCKO()
|
||||||
|
|||||||
Reference in New Issue
Block a user