HTTP-сервер Python поддерживает соединение - PullRequest
0 голосов
/ 01 мая 2018

Я пытаюсь протестировать HTTP-клиент, написанный на C, который отправляет HTTP-запрос POST на локальный сервер на моем компьютере. Я добавил заголовки keep-alive в свой запрос POST, который выглядит так на HTTP-сервере python3, работающем на моем компьютере:

<ip-address-1> - - [29/Apr/2018 18:27:49] "POST /html HTTP/1.1" 200 -
Host: <ip-address-2>
Content-Type: application/json
Content-Length: 168
Connection: Keep-Alive
Keep-Alive: timeout=5, max=100


INFO:root:POST request,
Body:
{
"field": "abc",
"time": "2018-04-29T01:27:50.322000Z" 
}

Обработчик POST HTTP-сервера выглядит следующим образом:

class S(BaseHTTPRequestHandler):
    def _set_response(self):
        self.send_response(200)
        self.send_header('Content-type', 'text/html')
        self.send_header("Connection", "keep-alive")
        self.send_header("keep-alive", "timeout=5, max=30")
        self.end_headers()

    def do_POST(self):
        content_length = int(self.headers['Content-Length']) # <--- Gets the size of data
        post_data = self.rfile.read(content_length) # <--- Gets the data itself
        print(self.headers)
        logging.info("POST request,\nBody:\n%s\n", post_data.decode('utf-8'))

        self._set_response()
        self.wfile.write("POST request for {}".format(self.path).encode('utf-8'))

def run(server_class=HTTPServer, handler_class=S, port=8080):
    logging.basicConfig(level=logging.INFO)
    server_address = ('', port)
    httpd = server_class(server_address, handler_class)
    logging.info('Starting httpd...\n')
    try:
        httpd.serve_forever()
    except KeyboardInterrupt:
        pass
    httpd.server_close()
    logging.info('Stopping httpd...\n')

Ответ заголовка, который я вижу на стороне клиента:

HTTP/1.0 200 OK
Server: BaseHTTP/0.6 Python/3.5.2
Date: Tue, 29 April 2018 16:07:42 GMT
Content-type: text/html
Connection: keep-alive
keep-alive: timeout=5, max=30

Я все равно получаю обратный вызов разъединения, поэтому мой вопрос: как я могу установить параметры соединения keep-alive со стороны сервера?

1 Ответ

0 голосов
/ 02 мая 2018

По умолчанию BaseHTTPRequestHandler испускает ответы HTTP / 1.0, как вы можете видеть в HTTP/1.0 200 OK. HTTP/1.1 требуется для ответов поддержки активности, как видно из документа (или для версии 3 ):

protocol_version

Указывает версию протокола HTTP, используемую в ответах. Если установлено значение «HTTP / 1.1», сервер разрешит постоянные соединения HTTP; тем не менее, ваш сервер должен включать точную длину содержимого заголовок (используя send_header ()) во всех своих ответах клиентам. За Для обратной совместимости по умолчанию установлено значение «HTTP / 1.0».

Тогда, как вы можете видеть в цитате, вам нужно будет также указать правильную длину содержимого для вашего ответа.

Обратите внимание, что в настоящее время вы отправляете ответы без тела, вы должны использовать для этого код 204 (без содержимого) и добавить заголовок Content-length: 0 или добавить небольшое тело (с количеством правильных байтов в Content-Length, предупреждение, это не счетчик символов, это счетчик байтов, почти такой же в ascii7, но не в других кодировках).

...