HTTP

HTTP

Дима

Популярный вопрос на собеседовании веб-разработчиков часто звучит так: «Что происходит после того, как в браузер ввели адрес сайта?». Подробный ответ на этот вопрос можно найти здесь. Главное, что хочет услышать собеседующий — ваш уровень понимания HTTP (Hyper-Text Transferring Protocol).

Для начала пару слов о том, что такое протокол. Протокол — это набор соглашений, правил, по которым разные программы могут обмениваться информацией. HTTP — это набор правил, который известен и вашему компьютеру и физически отдалённому компьютеру. С помощью него общаются браузер и веб-сервер.

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

Пример http-сессии (запрос-ответ) через программу curl:

$ curl --head -v ru.code-basics.com
* Rebuilt URL to: ru.code-basics.com/
*   Trying 104.28.3.115...
* Connected to ru.code-basics.com (104.28.3.115) port 80 (#0)
> HEAD / HTTP/1.1
> Host: ru.code-basics.com
> User-Agent: curl/7.47.0
> Accept: */*
>
< HTTP/1.1 301 Moved Permanently
HTTP/1.1 301 Moved Permanently
< Date: Mon, 30 Sep 2019 14:18:04 GMT
Date: Mon, 30 Sep 2019 14:18:04 GMT
< Connection: keep-alive
Connection: keep-alive
< Cache-Control: max-age=3600
Cache-Control: max-age=3600
< Expires: Mon, 30 Sep 2019 15:18:04 GMT
Expires: Mon, 30 Sep 2019 15:18:04 GMT
< Location: https://ru.code-basics.com/
Location: https://ru.code-basics.com/
< Server: cloudflare
Server: cloudflare
< CF-RAY: 51e6d2f1db12bdc8-AMS
CF-RAY: 51e6d2f1db12bdc8-AMS

<
* Connection #0 to host ru.code-basics.com left intact

http нужно не просто знать, но и уметь делать сырые http-запросы — не косвенно через браузер, а самостоятельно, эмулируя поведение браузера. Для этой задачи используют программу telnet. На Хекслете есть соответствующий курс и там мы всему научимся.

Для чего требуется знание http?

  • Работа с формами, загрузка файлов, перенаправления.
  • Аутентификация целиком зависит от http.
  • Извлечение информации о запросе (например, определение браузера, из которого был выполнен запрос).
  • Увеличение производительности. Кеширование.
  • Обеспечение безопасности. http — текстовый протокол без шифрования, он не безопасен.

https

Кроме http, в сети всё большее распространение получает https. Каждый пользователь сети должен знать, что нельзя выполнять действия, связанные с любыми секретными данными (например кредитками), на страницах, работающих по протоколу http. В таком случае любой человек, имеющий доступ к оборудованию, которое лежит между вами и сервером, обслуживающим сайт, сможет прочитать эти данные. Обратите внимание, что на популярных сайтах страницы оплаты всегда отдаются по https. В свою очередь, умение работать с https сразу добавляет новые понятия:

  • Шифрование, асимметричное шифрование
  • Сертификаты
  • Цифровая подпись

TCP/IP

Но одним http обойтись не получится. Дело в том, что http существует не сам по себе, а поверх стека протоколов TCP/IP. Базовое знание сетей важно по следующим причинам:

  • Безопасность. Очень легко совершить ошибку и быть взломанным.
  • Отладка. Немалая часть вопросов запуска и конфигурирования сайтов и их частей (в том числе базы данных) связана с сетевыми сокетами. Не зная сети вы будете останавливаться на любой простейшей проблеме без понимания, что вообще делать.

DNS

Ещё один столп веба — DNS, служба доменных имён. Каждый раз, когда мы вбиваем адрес в браузер, он выполняет DNS запросы к соответствующим серверам для выяснения того, какой ip-адрес принадлежит сайту. Дело в том, что соединение с сервером идёт по tcp/ip, а не по http. http начинает работать уже после того, как было установлено tcp соединение. Знание DNS важно по следующим причинам:

  • Зная DNS вы сможете не только купить домен, но и привязать его к вашему серверу
  • Почта для домена, верификация вашего проекта различными сервисами — всё это работает через возможности DNS
  • Опять же, отладка. Нередко проблемы загрузки связаны с DNS.



Report Page