Используйте многопоточность, чтобы позволить веб-серверу обрабатывать доступ нескольких пользователей одновременно. Когда соединение между клиентом и сервером успешно установлено, создается подпоток, который используется для специальной обработки запроса клиента, чтобы предотвратить блокировку основного потока. Установите созданный подпоток в качестве защитного основного потока, чтобы основной поток не смог выйти.
import threading
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
Задайте имя цели и передайте параметр new_socket в виде кортежа.
sub_thread = threading.Thread(target=handle_client_request, args=(new_socket,))
sub_thread.setDaemon(True)
sub_thread.start()
import socket
import threading
# Обрабатывать запросы клиентов
def handle_client_request(new_socket):
# Код выполняется до этого момента, что указывает на то, что соединение успешно установлено.
recv_client_data = new_socket.recv(4096)
if len(recv_client_data) == 0:
print("Закройте браузер")
new_socket.close()
return
# Декодировать двоичные данные
recv_client_content = recv_client_data.decode("utf-8")
print(recv_client_content)
# Разделить по указанной строке, Максимальное количество делений указано как 2.
request_list = recv_client_content.split(" ", maxsplit=2)
# Получить запрошенный путь к ресурсу
request_path = request_list[1]
print(request_path)
# Определите, относится ли запрос к корневому каталогу. Если условие истинно, верните указанные данные домашней страницы.
if request_path == "/":
request_path = "/index.html"
try:
# Динамическое открытие указанного файла
with open("static" + request_path, "rb") as file:
# Чтение данных файла
file_data = file.read()
except Exception as e:
# Запрошенный ресурс не существует, и возвращаются данные 404.
# строка ответа
response_line = "HTTP/1.1 404 Not Found\r\n"
# Заголовок ответа
response_header = "Server: PWS1.0\r\n"
with open("static/error.html", "rb") as file:
file_data = file.read()
# тело ответа
response_body = file_data
# Объединение ответных сообщений
response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body
# Отправить данные
new_socket.send(response_data)
else:
# строка ответа
response_line = "HTTP/1.1 200 OK\r\n"
# Заголовок ответа
response_header = "Server: PWS1.0\r\n"
# тело ответа
response_body = file_data
# Объединение ответных сообщений
response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body
# Отправить данные
new_socket.send(response_data)
finally:
# Закройте сокет между службой и клиентом
new_socket.close()
# Функция входа в программу
def main():
# Создать сокет TCP-сервера
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# Установить повторное использование номера порта, Порт выхода программы освобождается немедленно
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
# Привязать номер порта
tcp_server_socket.bind(("", 9000))
# Настроить прослушивание
tcp_server_socket.listen(128)
while True:
# Ожидание принятия запроса на подключение клиента
new_socket, ip_port = tcp_server_socket.accept()
print(ip_port)
# Когда клиент и сервер устанавливают процесс соединения, создайте дочерний поток.
sub_thread = threading.Thread(target=handle_client_request, args=(new_socket,))
# Настройте основной поток демона
sub_thread.setDaemon(True)
# Запустите дочерний поток для выполнения соответствующей задачи.
sub_thread.start()
if __name__ == '__main__':
main()