Форум программистов, компьютерный форум, киберфорум
Python: Сети
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
102 / 75 / 38
Регистрация: 08.11.2017
Сообщений: 272

TCP клиент asycnio

27.04.2018, 13:46. Показов 1372. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Пытаюсь реализовать TCP клиент на Python, есть некоторые вопросы. Есть протокол общения, первые 4 байта размер посылки, далее сама посылка. Так вот я хочу что бы у меня была функция которая читает данные из сокета и в зависимости какая команда пришла запускать функцию и записывать результат её выполнения в сокет. Первый вопрос как считывать данные из сокета и отсекать окончание сообщения, то есть обычно из сокета читают по кускам (пример, 1024, 2048) и когда программа считала 1024 байта, конец этой байтовой строки может быть в середине следующего сообщения или наоборот сообщение длинной 1300 байт и в один кусок он не помещается. Второй вопрос функция которая принимает данные из сокета и вызывает другие в зависимости от того что пришло должна быть асинхронной или же функции которые она вызывает должны быть асинхронными? Набросал пару вариантов, может бы есть у кого то примеры? в интернете есть примере простых эхо клиентов, но что бы с размерами посылок не встречал. Спасибо за помощь.
Кликните здесь для просмотра всего текста
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
import asyncio
import socket
import json
 
host = '192.168.1.2'
port = 6666
loop = asyncio.get_event_loop()
connection = socket.create_connection((host, port))
 
async def handler(conn):
    while True:
        msg = await loop.sock_recv(conn, 1024)
        print(msg)
        if "command_1" in msg.decode():
            command_1(msg)
        elif "command_2" in msg.decode():
            command_1(msg)
        if not msg:
            break
        
 
def command_1(self, message):
        response = json.loads(message)
        test = {"status":"ok"}
        data_for_send = json.dumps(test, ensure_asii=False).encode()
        #здесь был кусок который ставил в начало размер послыки  
        #отправляю в сокет
        connection.sendall(data_for_send)
    
def command_2(self, message):
        response = json.loads(message)
        test = {"status":"bad"}
        data_for_send = json.dumps(test, ensure_asii=False).encode()
        #здесь был кусок который ставил в начало размер послыки  
        #отправляю в сокет
        connection.sendall(data_for_send)
 
 
loop.create_task(handler(connection))
loop.run_forever()
loop.close()


Кликните здесь для просмотра всего текста
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import asyncio
import json
 
class ClientProtocol(asyncio.Protocol):
    def __init__(self, loop):
        self.loop = loop
 
    def connection_made(self, transport):
        self.transport = transport
 
    def data_received(self, data):
        len_message = int.from_bytes(data[0:3], byteorder="little")
        message = data[4:len_message]
        decoded_msg = message.decode()
        print(decoded_msg)
        if "command_1" in decoded_msg:
            self.command_1(decoded_msg)
        elif "command_2" in decoded_msg:
            self.command_2()
 
    def connection_lost(self, exc):
        print('The server closed the connection')
        print('Stop the event loop')
        self.loop.stop()
 
    def command_1(self, message):
        response = json.loads(message)
        test = {"status":"ok"}
        data_for_send = json.dumps(test, ensure_asii=False).encode()
        #здесь был кусок который ставил в начало размер послыки  
        #отправляю в сокет
        self.transport.write(data_for_send)
 
    def command_2(self, message):
        response = json.loads(message)
        test = {"status":"bad"}
        data_for_send = json.dumps(test, ensure_asii=False).encode()
        #здесь был кусок который ставил в начало размер послыки  
        #отправляю в сокет
        self.transport.write(data_for_send)
 
 
 
loop = asyncio.get_event_loop()
 
coro = loop.create_connection(lambda: ClientProtocol(loop),
                            '192.168.1.2', 6666)
loop.run_until_complete(coro)
loop.run_forever()
loop.close()
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.04.2018, 13:46
Ответы с готовыми решениями:

TCP-сервер и TCP-клиент. Клиент не находит файл.
Всем привет! Решил изучать передачу данных по сети и начал с освоения примера, приведённого в книге "Visual C# 2008. Базовый курс...

Сцена зависает при запуске TCP-клиента, когда он подключен к TCP - серверу, при этом TCP-клиент полностью функционирует
Проблема описана в заголовке, и хотелось бы услышать ваше мнение, о том как можно решить проблему. Скрипт TCP-клиента на сцене: ...

Если сервер TCP то и клиент тоже должен быть TCP?
Я полный новичок И я так понимаю есть TCP client (Sockets), TCP server (Sockets), и ClientSocket (ScktComp), ServerSocket (ScktComp) ...

3
963 / 718 / 276
Регистрация: 10.12.2016
Сообщений: 1,764
27.04.2018, 20:33
Цитата Сообщение от kratorr Посмотреть сообщение
обычно из сокета читают по кускам (пример, 1024, 2048
сокет читает байты пока они приходят, тут надо самому маркеры начала и конца ставить
посмотрите client-server Protocol https://docs.python.org/3/libr... tocol.html
0
102 / 75 / 38
Регистрация: 08.11.2017
Сообщений: 272
28.04.2018, 16:01  [ТС]
Немного подумал и переписал функцию data_recivied, так как сообщения приходят в формате json пытаюсь сделать json.loads, если всё ок, то чищу буфер. Подойдет ли такой подход?
Кликните здесь для просмотра всего текста
Python
1
2
3
4
5
6
7
8
9
    def data_received(self, data):
        self.buffer += data
        len_msg = self._byte_to_len(self.buffer[:4])
        try:
            json_msg = json.loads(self.buffer[4:len_msg+4])
            self._process_command(json_msg)
            self.buffer = self.buffer[len_msg+4:]
        except:
            pass
0
963 / 718 / 276
Регистрация: 10.12.2016
Сообщений: 1,764
28.04.2018, 17:22
так делайте и клиента и сервер на протоколе
https://docs.python.org/3/libr... t-protocol
сообщения произвольной длины принимает
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.04.2018, 17:22
Помогаю со студенческими работами здесь

Не приходит ответ на TCP клиент андроид с TCP сервера Qt
У меня есть TCP клиент андроид и TCP сервер Qt с клиента на сервер сообщения доходят нормально. Ну а с сервера на клиент сообщения(ответы)...

как создать TCP клиент, TCP сервер ? На С++
Очень нужна помощь!Как написать TCP клиент, TCP сервер. Например,клиент вводит строку с клавиатуры и отсылает ее серверу.только перед...

Написать TCP-клиент и TCP-сервер.
Написать TCP-клиент и TCP-сервер. Учтите наличие сложностей написания программы под Windows, связанных с переносимостью и Windows-функцией...

TCP-клиент
СЕРВЕР: // Пример простого TCP-эхо-сервера #include <stdio.h> #include <winsock2.h> // Wincosk2.h должен быть раньше windows! ...

Tcp клиент
Код tcp клиента ;; yasm -g dwarf2 -f elf64 -a x86 message.asm -o msg.o ;; ld -o msg msg.o segment .bss listen_socket:...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru