Linux Auto Wi-Fi поиск подключиться и отключиться с помощью Python - PullRequest
0 голосов
/ 03 июля 2019

Я пишу код для клиента и сервера, в котором клиент будет искать сеть, автоматически подключаться и делиться некоторой информацией.теперь, если сеть находится вне зоны доступа клиента, клиент отключается с этим.как я могу это сделать.Ранее я использовал UDP-сокет в клиенте и на сервере, в котором я использовал скрипт для поиска подключенных IP-адресов и клиента в точке доступа Wi-Fi на сервере.и если это действительно ip, который ищет сервер, то он передает некоторые сообщения.но на стороне клиента, клиент должен также найти соединение Wi-Fi, а затем подключиться к нему.Ранее я использовал UDP-сокет в клиенте и на сервере, в котором я использовал скрипт для поиска подключенных IP-адресов и клиента в точке доступа Wi-Fi на сервере.и если это действительно ip, который ищет сервер, то он передает некоторые сообщения.но на стороне клиента, клиент должен также найти соединение Wi-Fi, а затем подключиться к нему.потому что клиент движется, и он будет подключаться и отключаться от сервера снова и снова.Таким образом, когда я запускаю программу, клиент и сервер отправляют данные, но когда клиент находится вне диапазона сервера и снова подключается к нему (тот же сервер), клиент застревает.клиент отправляет данные каждые 2 сек.времени.

    # -*- coding: utf-8 -*-
"""
Created on Tue Apr  2 10:29:46 2019

@author: Gaurav Sharma
"""

import os, time
import re
import threading, UDPComm, RSA, base64

private_key , public_key = RSA.generate_keys()
encrypt_str = "encrypted_message="
iplist={'10.42.0.50':'101','10.42.0.91':'102'}

#arr = array.array('
class ClientThread(threading.Thread):
    def __init__(self,clientAddress, clientRegNo,clientPort):
        threading.Thread.__init__(self)
        self.clientAddress = clientAddress
        self.clientPort = clientPort
        self.clientRegNo = clientRegNo
        self.client_public_key=""
        self.clientValid=False
        self.keyExchanged=False
        self.ConnEstablised=False
        print ("New connection incoming: ", (clientAddress, clientPort))
    def run(self):
        sock = UDPComm.getSock((self.clientAddress, self.clientPort))
        print ("Connection from : ", (self.clientAddress, self.clientPort))
        #self.csocket.send(bytes("Hi, This is from Server..",'utf-8'))
        UDPComm.sendTo(sock, "Server:Handshake", "", (self.clientAddress, self.clientPort))
        while True:

            sock.settimeout(10)
            try:
                data = sock.recv(1024)
                time.sleep(1)
            except Exception as e:
                print (e)
                break
            try:
                msg = base64.b64decode(data)
                print ("Message from client", msg)
            except Exception as e:
                print (e)

            if self.ConnEstablised:
                print ("Received:\nEncrypted message = "+str(data))
                decrypted = RSA.decrypt_message(data, private_key)
                decrypted = decrypted.replace(encrypt_str, '')
                print ("Decrypted message = " + decrypted)
                UDPComm.sendTo(sock, "Server:OK", self.client_public_key, (self.clientAddress, self.clientPort))
                continue

            if self.keyExchanged:
                print ("Received:\nEncrypted message = "+str(data))
                decrypted = RSA.decrypt_message(data, private_key)
                decrypted = decrypted.replace(encrypt_str, '')
                print ("Decrypted message = " + decrypted)
                if decrypted=="Client:OK":
                    print("Successfully exchanged keys")
                    UDPComm.sendTo(sock, "Server:OK", self.client_public_key, (self.clientAddress, self.clientPort))

                    self.ConnEstablised=True
                    continue
                else:
                    print("Failed to establish Connection")
                    break

            if self.clientValid:
                if len(data)>0:
                    self.client_public_key = RSA.importKey(data)
                    print("Client public key received")
                    UDPComm.sendTo(sock, "Server:OK", self.client_public_key, (self.clientAddress, self.clientPort))
                    self.keyExchanged=True
                    continue
                else:
                    print("Failed to Exchange keys")
                    break

            if 'Client:AckHandshake:' in msg:
                msg = msg.replace('Client:AckHandshake:','')
                if msg==self.clientRegNo:
                    UDPComm.sendTo(sock, public_key.exportKey(), "key", (self.clientAddress, self.clientPort))
                    print ("Public key sent to client.")
                    self.clientValid=True
                    continue
                else:
                    print("Failed to authorize client")
                    break


        print ("Client at ", (self.clientAddress,self.clientPort) , " disconnected...")


def getIPs():    
    global iplist
    myCmd = os.popen('./show_client.sh').read()
    IPs = myCmd.split()
    r = re.compile(r"^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$")
    IPs = (filter(r.match, IPs))
    print("Connected IPs:", IPs)
    a = set(IPs)
    b = set([x for x in iplist])
    c = a & b
    if c:
        print("Valid IPs", c)
    else:
        print("No valid IPs detected")
    return c

def getNeighbours():
    global new_list, old_list, hello, byebye, iplist
    new_list = getIPs()
    hello = set(new_list) - set(old_list)
    byebye = set(old_list) - set(new_list)

    if len(hello)>0 and len(byebye)>0:
        print("The Following IP's joined new\n", hello)
        print("value of Ip\n", new_list)
        print("The Following IP's disconnected new\n", byebye)
        old_list = set(new_list)
    elif len(hello)>0:
        print("The Following IP's joined new\n", hello)
        old_list = set(new_list)
    elif len(byebye)>0:
        print("The Following IP's disconnected new\n", byebye)
        old_list = set(new_list)
    else:
        print("No changes")
    for ips in hello:
        clientAddress=ips
        clientRegNo = iplist[clientAddress]
        clientPort=12345
        newthread = ClientThread(clientAddress, clientRegNo, clientPort)
        newthread.start()

def WifiListener():
    print("WifiListener  started")
    while(True):
        getNeighbours()
        time.sleep(5)

LOCALHOST = "127.0.0.1"
#clientPort = 12345
#clientAddress = '' #used for all communication
PORT= 12345
old_list=set()
new_list=set()
hello=set()
byebye=set()
thread1 = threading.Thread(target = WifiListener)
thread1.start()
#WifiListener()
print("Server started")
print("Waiting for client request..") 

А вот код клиента

   import socket
"""
@ author gaurav sharma
"""
import UDPComm
import RSA
import base64

UDP_IP = '0.0.0.0'
UDP_PORT = 12345

private_key , public_key = RSA.generate_keys()
encrypt_str = "encrypted_message="

clientRegNo = "101" #take from db

server_public_key=""
sock = socket.socket(socket.AF_INET, # Internet
                     socket.SOCK_DGRAM) # UDP
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
sock.bind((UDP_IP, UDP_PORT))

step=0

while True:
    data, addr = sock.recvfrom(1024) # buffer size is 1024 bytes
    #data = unicode(data, errors='ignore')
    try:
        msg = base64.b64decode(data)
    except Exception as e:
        print(e)
        msg=''
    print ("Received:",msg)
    print ("Received from:", addr)

    if msg=="Server:Handshake":
        message = "Client:AckHandshake:"+clientRegNo
        UDPComm.sendTo(sock, message, "", addr)
        step=1
        continue

    if step==1:
        #data = data.replace("Server:PublicKey", '')
        #data=data.replace("\r\n", '')
        if len(data)>0:
            print("Server pubic key received!")
            server_public_key = RSA.importKey(data)
            message = public_key.exportKey()
            UDPComm.sendTo(sock, message, "key", addr)
            step=2
            continue
        else:
            print("Unable to Establish connection")


    if step==2:
        decrypted = RSA.decrypt_message(data, private_key)
        decrypted = decrypted.replace(encrypt_str, '')
        print ("Decrypted message = " + decrypted)
        if decrypted=="Server:OK":
            print("Succesfully exchanged keys")
            message = "Client:OK"
            UDPComm.sendTo(sock, message, server_public_key, addr)
            step=3
            continue
        else:
            print("Unable to exchange keys")

    if step==3:
        decrypted = RSA.decrypt_message(data, private_key)
        decrypted = decrypted.replace(encrypt_str, '')
        print ("Decrypted message = " + decrypted)
        if decrypted=="Server:OK":
            message = "Client:OK"
            UDPComm.sendTo(sock, message, server_public_key, addr)
        else:
            print("Not connected to any server")
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...