javascript

HTTP-запросы: структура, методы, строка статуса и коды состояния

  • вторник, 10 декабря 2024 г. в 00:00:08
https://habr.com/ru/articles/865040/

HTTP-запросы: структура, методы, строка статуса и коды состояния

Цель: написать небольшую статью, максимально понятным языком,
которая дает представление о протоколе http и объясняет структуру http запросов и ответов сервера.

В этой статье мы рассмотрим структуру HTTP-запросов, методы, которые используются для выполнения различных операций,
статусную строку и коды состояния, которые помогают понять, успешно ли был выполнен запрос.

Заголовок: HTTP-запроса: Структура, методы, статусная строка и коды состояния

Введение и термины

В этой статье мы рассмотрим основные аспекты HTTP-запросов, их структуру, методы и коды состояния. Мы также объясним, что такое строка статуса в ответе сервера.

HTTP (HyperText Transfer Protocol) — это протокол прикладного уровня, который используется для передачи данных между веб-сервером и клиентом.
Он является основой работы интернета и обеспечивает обмен информацией между различными устройствами и приложениями.
Протокол позволяет пользователям запрашивать ресурсы, такие как веб-страницы, изображения и другие файлы, с сервера на свой компьютер.

URI (Uniform Resource Identifier) — это уникальный идентификатор, который используется для обозначения ресурсов в интернете. Это может быть веб-страница, файл, изображение и т. д.

URI состоит из нескольких частей:

Схема. Определяет тип ресурса и протокол, используемый для доступа к нему. Например, «http» для веб-страниц или «ftp» для файлов на FTP-сервере.
Хост. Указывает на сервер, на котором находится ресурс.
Путь. Описывает расположение ресурса на сервере.
Параметры. Дополнительные данные, которые могут быть переданы вместе с запросом на ресурс.
Например, URI для этой страницы может выглядеть так: «https://yandex.ru/q/1302754986/». Здесь «https» — схема, «yandex.ru» — хост, а «q/1302754986» — путь.

Когда вы вводите URI в браузере, он отправляет запрос на соответствующий сервер и получает от него ответ. Этот ответ может быть страницей, файлом, изображением и т. п.

Таким образом, URI — это способ идентификации ресурсов в сети, который позволяет нам получать доступ к ним и взаимодействовать с ними.

Структура HTTP-запроса

HTTP-запрос состоит из трёх основных частей:

  1. Метод: определяет тип действия, которое клиент хочет выполнить на сервере. Например, GET, POST, PUT, DELETE.

  2. Путь: указывает на ресурс, к которому клиент хочет получить доступ. Например, /index.html, /images/logo.png.

  3. Заголовки: содержат дополнительную информацию о запросе, такую как тип содержимого, кодировка, авторизация и т. д.

Каждый HTTP-запрос состоит из следующих частей:

Заголовки запроса - содержат информацию о запросе, такую как метод, URI, версия протокола и заголовки HTTP.

Тело запроса - содержит данные, которые необходимо отправить на сервер (например, форма для отправки).

Статусная строка - содержит информацию о статусе запроса и может включать в себя код состояния HTTP и сообщение.

Заголовки ответа - аналогичны заголовкам запроса, но содержат информацию об ответе сервера.

Тело ответа - содержит данные, отправленные сервером в ответ на запрос.

Пример HTTP-запроса:

GET /index.html HTTP/1.1
Host: example.com
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.82 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Language: ru-RU,ru;q=0.9
Connection: close

Здесь метод — GET, путь — /index.html. Заголовки содержат информацию о браузере клиента, типе содержимого, языке и способе соединения.

Методы HTTP
Существует несколько методов HTTP, которые определяют тип действия, выполняемого на сервере.
Наиболее часто используемые методы:

GET - используется для получения ресурса с сервера (например, веб-страницы).
POST - используется для отправки данных на сервер.
PUT - используется для обновления ресурса на сервере (например, обновление страницы).
DELETE - используется для удаления ресурса на сервере.

Это лишь некоторые из наиболее распространённых методов. Полный список методов можно найти в спецификации HTTP.

Коды состояния HTTP

Строка статуса

Строка статуса — это часть ответа сервера, которая содержит информацию о статусе запроса.
Она состоит из трёх частей: код состояния, описание кода и версия протокола.

Примеры строк статуса:

  • 200 OK: запрос выполнен успешно.

  • 404 Not Found: запрашиваемый ресурс не найден.

  • 500 Internal Server Error: на сервере произошла ошибка.

Код состояния — это числовое значение, которое указывает на результат запроса. Описание кода — это текстовое объяснение кода состояния. Версия протокола — это версия HTTP, используемая сервером.

Коды состояния HTTP сообщают, была ли операция успешной или нет.

Некоторые из наиболее часто используемых кодов состояния:

200 OK - означает, что запрос был успешным и сервер вернул ответ.
404 Not Found - означает, что сервер не смог найти запрошенный ресурс.
500 Internal Server Error - означает, что на сервере произошла ошибка, и запрос не может быть выполнен.

Коды состояния делятся на пять категорий:

  • 1xx: информационные ответы.

  • 2xx: успешные ответы.

  • 3xx: перенаправления.

  • 4xx: ошибки клиента.

  • 5xx: ошибки сервера.

Полный список кодов состояния можно найти в спецификации HTTP.

Выводы:

Теперь, когда вы знаете структуру HTTP-запросов, основные методы и коды состояния HTTP, вы можете лучше понять,
как работает протокол HTTP и как выполнять различные операции в Интернете.
Если вы хотите узнать больше о протоколе HTTP,
рекомендуем изучить спецификации RFC и другие источники информации.

Примеры запросов на JavaScript

Пример GET-запроса:

const request = new XMLHttpRequest(); request.open('GET', 'https://example.com/api/endpoint', true); request.onload = function() { if (this.status >= 200 && this.status < 300) { console.log(this.responseText); } else { alert(this.status + ': ' + this.statusText); } }; request.send();

Пример POST-запроса:

var request = new XMLHttpRequest(); var url = 'https://api.example.com/endpoint'; var params = 'name=John+Doe&age=30'; request.open("POST", url, true); request.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); request.onload = function() { if (request.status >= 200 && request.status < 400) { var response = JSON.parse(request.response); console.log(response.result);} else { alert(“Error!”); } }; var data = params; request.send(data);

В этих примерах используются методы XMLHttpRequest для выполнения HTTP-запросов.
Вы также можете использовать библиотеки, такие как Axios или Fetch,
которые упрощают выполнение HTTP-запросов в JavaScript.

XMLHttpRequest (XHR) - это объект в браузерах, который позволяет JavaScript-приложениям отправлять и получать данные от сервера по протоколу HTTP.
Методы XHR включают в себя open(), send() и другие, которые позволяют выполнять различные операции с HTTP-запросами и ответами.

Да, методы XMLHttpRequest можно использовать в реальной разработке.
Они являются стандартным способом выполнения HTTP-запросов из JavaScript в браузерах и широко используются в веб-разработке.
Однако стоит отметить, что существуют и другие библиотеки, такие как Fetch или Axios,
которые предоставляют более удобный и современный способ выполнения HTTP-запросов в JavaScript, и их также можно использовать в реальных проектах.

Заключение

HTTP — это важный протокол, который обеспечивает работу интернета.
Понимание структуры HTTP-запросов и ответов,
а также методов и кодов состояния, поможет вам лучше понимать,
как работает интернет и как взаимодействовать с веб-сервисами.