|
| 1 | +import wifi |
| 2 | +wifi.try_connect() |
| 3 | + |
| 4 | +from XAsyncSockets import XAsyncSocketsPool, XAsyncUDPDatagram |
| 5 | +from _thread import start_new_thread |
| 6 | + |
| 7 | +class NetServer: |
| 8 | + Pool = None |
| 9 | + |
| 10 | + def __init__(self, Server = ('0.0.0.0', 32)): |
| 11 | + if NetServer.Pool is None: |
| 12 | + NetServer.Pool = XAsyncSocketsPool() |
| 13 | + start_new_thread(NetServer.run_forever, ()) |
| 14 | + |
| 15 | + self.UDPDatagram = XAsyncUDPDatagram.Create(NetServer.Pool, Server, 256) |
| 16 | + self.UDPDatagram.OnDataRecv = NetServer._onUDPDatagramDataRecv |
| 17 | + self.UDPDatagram.OnFailsToSend = NetServer._onUDPDatagramFailsToSend |
| 18 | + print("LocalAddr : %s:%s" % self.UDPDatagram.LocalAddr) |
| 19 | + |
| 20 | + def exit(self): |
| 21 | + self.UDPDatagram.Close() |
| 22 | + |
| 23 | + def unit_test(self): |
| 24 | + import time |
| 25 | + Remote = ('10.10.10.237', 9954) |
| 26 | + data = bytearray(u"1231") |
| 27 | + while True: |
| 28 | + self.UDPDatagram.AsyncSendDatagram(datagram=data, remoteAddr=Remote) |
| 29 | + print(data) |
| 30 | + time.sleep(2) |
| 31 | + |
| 32 | + def run_forever(): |
| 33 | + try: |
| 34 | + NetServer.Pool.AsyncWaitEvents() |
| 35 | + finally: |
| 36 | + NetServer.Pool.StopWaitEvents() |
| 37 | + |
| 38 | + def _onUDPDatagramDataRecv(xAsyncUDPDatagram, remoteAddr, datagram): |
| 39 | + print('On UDP Datagram Data Recv (%s:%s) :' % remoteAddr, bytes(datagram), xAsyncUDPDatagram) |
| 40 | + |
| 41 | + def _onUDPDatagramFailsToSend(xAsyncUDPDatagram, datagram, remoteAddr): |
| 42 | + print('On UDP Datagram Fails To Send', bytes(datagram), remoteAddr, xAsyncUDPDatagram) |
| 43 | + |
| 44 | +if __name__ == '__main__': |
| 45 | + client = NetServer() |
| 46 | + client.unit_test() |
| 47 | + client.exit() |
0 commit comments