zchat.py 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. import socket
  2. import sys
  3. import time
  4. import select
  5. import zlib
  6. import base64
  7. import json
  8. import _thread
  9. def dummyCB(msg):
  10. print("dummy_CB",msg)
  11. class Server():
  12. def __init__(self,cb=dummyCB,port=51000):
  13. print("**** SERVER *****")
  14. self._t = time.time()
  15. self._last_check = time.time()
  16. self.port=port
  17. self.cb = cb
  18. self.clients = []
  19. self.msg=b''
  20. self.select = select.select
  21. self._start()
  22. def _start(self):
  23. self.server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  24. self.server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
  25. #self.xs.getsockopt(socket.AF_INET, socket.SO_REUSEADDR )
  26. while 1:
  27. try:
  28. self.server.bind(("", self.port))
  29. break
  30. except Exception as e:
  31. print("except",e)
  32. print( "bind error")
  33. time.sleep(1)
  34. self.server.listen(1)
  35. self.client_loop()
  36. def time(self):
  37. return self._t - time.time()
  38. def client_loop(self):
  39. self.client_lock = _thread.allocate_lock()
  40. print(dir(self.client_lock),"-----2:") # = _thread.allocate_lock()
  41. _thread.start_new_thread(self._client_loop,())
  42. def _client_loop(self):
  43. print("---- start server loop ----")
  44. while 1:
  45. try:
  46. client, addr = self.server.accept()
  47. client.setblocking(0)
  48. self.client_lock.acquire()
  49. self.clients.append(client)
  50. print("+++ Client %s open" % addr[0])
  51. finally:
  52. self.client_lock.release()
  53. time.sleep(0.2)
  54. def rem_client(self,client):
  55. self.client_lock.acquire()
  56. try:
  57. self.clients.remove(client)
  58. #print(dir(client))
  59. #print((client.family.name))
  60. print("+++ Client %s close" % client)
  61. finally:
  62. self.client_lock.release()
  63. def get_clients(self):
  64. self.client_lock.acquire()
  65. clients = self.clients[:]
  66. self.client_lock.release()
  67. return clients
  68. def _recv(self,sock):
  69. xmsg=b""
  70. try:
  71. msg = b""
  72. xmsg = sock.recv(1)#1024)#5120)
  73. while xmsg:
  74. #print(xmsg)
  75. msg += xmsg
  76. xmsg = sock.recv(1)
  77. idle = 0
  78. except ConnectionResetError as e:
  79. pass
  80. except BlockingIOError as e:
  81. pass
  82. if xmsg:
  83. print("B64",sys.getsizeof(msg),len(msg))
  84. msg = base64.b64decode(msg)
  85. #msg = msg.decode("utf8")
  86. print("str",sys.getsizeof(msg),len(msg))
  87. try:
  88. msg=zlib.decompress(msg)
  89. print("uzip",sys.getsizeof(msg),len(msg))
  90. except Exception as e:
  91. print("SERVER decompress err",e)
  92. return xmsg
  93. def check_client(self):
  94. if self._last_check+1 < time.time():
  95. self._last_check = time.time()
  96. for sock in self.get_clients():
  97. try:
  98. sock.send(b".")
  99. except BrokenPipeError as e:
  100. self.rem_client(sock)
  101. except ConnectionResetError as e:
  102. self.rem_client(sock)
  103. def poll(self):
  104. run = 1
  105. #try:
  106. if 1: #while run:
  107. self.check_client()
  108. idle = 1
  109. for sock in self.get_clients():
  110. #print(dir(sock))
  111. msg = self._recv(sock)
  112. if not msg:
  113. continue
  114. idle = 0
  115. msg = msg.replace(b"\x00 ",b"")
  116. msg = {"cmd":msg}
  117. self.cb(msg)
  118. if idle:
  119. time.sleep(0.02)
  120. #finally:pass
  121. #except KeyboardInterrupt:
  122. # print(" strg+c")
  123. #finally:
  124. # for c in clients:
  125. # print(c,"close")
  126. # c.close()
  127. # server.close()
  128. # print("server close")
  129. CMD = Server
  130. def cmd(cb=dummyCB,port=51000):
  131. print("----cmd")
  132. x=CMD(cb=cb,port=port)
  133. while 1:
  134. x.poll()
  135. class Client():
  136. def __init__(self,port=51000):
  137. print("-----CLIENT-----")
  138. self.port = port
  139. self.connect()
  140. def connect(self,client_name="unkown"):
  141. self.xip = "127.0.0.1" #raw_input("IP-Adresse: ")
  142. self.xs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  143. try:
  144. self.xs.connect((self.xip, self.port)) #50000))
  145. except ConnectionRefusedError as e:
  146. print("ConnectionRefusedError: ", "ERR: {0} ".format(e.args) ,end="")
  147. print("Server nicht ereichbar/unterbrochen")
  148. time.sleep(1)
  149. self.connect()
  150. print("connected !")
  151. def send(self,nachricht):
  152. try:
  153. #print(sys.getsizeof(msg),len(msg))
  154. if sys.getsizeof(nachricht):
  155. nachricht=zlib.compress(nachricht)
  156. #nachricht = bytes(nachricht,"utf-8")
  157. nachricht = base64.b64encode(nachricht)
  158. self.xs.send(nachricht)
  159. except socket.error as e:
  160. self.connect()
  161. time.sleep(0.0001)
  162. def close(self):
  163. self.xs.close()
  164. def __del__(self):
  165. self.close()
  166. tcp_sender = Client
  167. if __name__ == "__main__":
  168. if "client" in sys.argv:
  169. c = Client()
  170. while 1:
  171. i = input("cmd:")
  172. c.send(bytes(i,"utf8"))
  173. else:
  174. server = Server()
  175. while 1:
  176. server.poll()
  177. time.sleep(0.00001)
  178. else:
  179. pass
  180. if 0:
  181. import random
  182. client = Client()
  183. for i in range(10):
  184. msg=bytes("hi"+str("x"*random.randint(10,9999)),"utf-8")
  185. print(sys.getsizeof(msg),len(msg))
  186. client.send(msg)
  187. time.sleep(0.01)
  188. client = Client()
  189. for i in range(10):
  190. msg=bytes("ho "+str("x"*random.randint(10,9999)),"utf-8")
  191. print(sys.getsizeof(msg),len(msg))
  192. msg=zlib.compress(msg)
  193. print(sys.getsizeof(msg),len(msg))
  194. client.send(msg)
  195. time.sleep(0.01)