НГРОК С Питоном и малиновым Пи

#python #python-3.x #django #raspberry-pi #ngrok

Вопрос:

Мне жаль возвращаться с новыми проблемами с ngrok/django, но это кажется очень непоследовательным. Я пытаюсь отправить строку с моего сайта django, размещенного на heroku, в перенаправленный сокет на моем raspberry pi. Тестирование как на веб-сайте, так и netcat SERVER:PORT (очевидно, отредактировано) Я получаю TTL(общее количество подключений), но в моем файле python ничего не происходит. Я не уверен, почему это происходит, но если кто-нибудь увидит что-то очевидное в моем коде или img, то помощь будет отличной!

https://imgur.com/a/OZzsDyT

Сценарий Pi

 
PORT = REDACTED
SERVER = '0.0.0.0'
ADDR = (SERVER, PORT)
FORMAT = 'utf-8'
DISCONNECT_MESSAGE = "!DISCONNECT!"
my_queue = queue.Queue()
print(SERVER)
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind(ADDR)


def handle_client(conn, addr):
    print(f"[NEW CONNECTION] {addr} connected")

    connected = True
    while connected:
        msg_length = conn.recv(HEADER).decode(FORMAT)
        if msg_length:
            msg_length = int(msg_length)
            msg = conn.recv(msg_length).decode(FORMAT)
            if msg == '!DISCONNECT!':
                connected = False
                print("disconnect")
                break
            else:
                my_queue.put(msg)
            print(f"[{ADDR}] {msg}")
            conn.send("MSG Received".encode(FORMAT))
    conn.close()
def start():
    server.listen()
    print(f"[LISTENING] Server Is Listening On {SERVER}")
    while True:
        conn, addr = server.accept()
        thread = threading.Thread(target=handle_client, args=(conn, addr))
        thread.start()
        print(f"[ACTIVE CONNECTIONS] {threading.activeCount() - 1}")

print("[Starting] Server")
threading.Thread(target=start).start()

msg = my_queue.get()
print(msg)
 

Вид на Джанго:

 HEADER = 64
PORT = REDACTED
SERVER = 'REDACTED'
ADDR = (SERVER, PORT)
FORMAT = 'utf-8'
DISCONNECT_MESSAGE = "!DISCONNECT!"

class RobotDetail(UpdateView):
    model = models.Robot
    form_class = RobotUpdateForm
    template_name = 'dashboard-home/robotdetail.html'

    def form_valid(self, form):
        self.object = form.save()
        client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        client.connect(ADDR)

        def send(msg):
            message = msg.encode(FORMAT)
            msg_length = len(message)
            send_length = str(msg_length).encode(FORMAT)
            send_length  = b' ' * (HEADER - len(send_length))
            client.send(send_length)
            client.send(message)

        send(form.cleaned_data['path_options'])
        send(DISCONNECT_MESSAGE)
        return render(self.request, "dashboard-home/thank-you.html")
 

Комментарии:

1. Для начала вы можете использовать что-то вроде pyngrok для автоматизации ngrok части этого потока для вас, что должно значительно облегчить вам и другим устранение неполадок.