Как я могу разрешить только запросы со своих веб-страниц на mydomain.com?
В двух словах, вы не можете. Любой инструмент, такой как почтальон или любой сценарий (такой как node.js, PHP, Perl, и т. д. c ...) может отправлять любые заголовки или другие параметры запроса, которые он хочет, поэтому заголовки сами по себе бесполезны для ограничения доступа только к веб-странице в ваш домен.
Так работает сеть.
Для ограничения доступа чаще всего требуется логин пользователя или подобные учетные данные (вероятно, установка повара ie, который вы можете проверить), а затем, если вы видите, что ваши API злоупотребляют, вы можете запретить / удалить конкретная c учетная запись пользователя, которая делает это.
Существуют и другие методы, которые могут заставить скрипты или инструменты использовать ваш API более эффективно, но даже они не защищены от хакера, который хочет заняться работой. Например, ваш сервер может генерировать токен, вставлять его на веб-страницу, а затем всякий раз, когда вы делаете запрос API с веб-страницы, вы добавляете токен с веб-страницы. Затем ваш сервер проверяет наличие действительного токена. Вы удостоверяетесь, что токены истекают через некоторое разумное время, чтобы хакер не мог просто получить их и использовать их в течение длительного времени.
Решительный хакер может по-прежнему вычищать токен с вашей веб-страницы всякий раз, когда он Я хочу использовать его, так что это всего лишь препятствие, а не то, что останавливает решительного хакера.
Единственное реальное решение здесь и то, что кто-то, например, пользователь Google, для своих API-интерфейсов, - требовать какие-то учетные данные при каждом вызове API. а затем инструктируйте сервер на злоупотребление API-интерфейсами (ограничение скорости, непреднамеренное использование и т. д. c ...), а затем отзовите эти учетные данные, если они используются не по назначению. Учетные данные могут быть токеном разработчика (как и в некоторых API Google) или могут быть какими-то учетными данными для аутентификации при входе пользователя (например, поваром ie).
Есть и другие хитрости раньше использовался там, где API работает правильно только в том случае, если перед ним предшествует последовательность запросов, которая обычно поступает с вашей веб-страницы. Это намного больше работы для реализации и поддержки, но если ваша веб-страница обычно выдает запрос на веб-страницу, затем делает два ajax вызова, затем запрашивает пять изображений и затем вызывает API, вы можете каким-то образом получить свой сервер отслеживать эту последовательность событий из указанного браузера c и только в том случае, если вы видите ожидаемую последовательность событий, которая выглядит так, как будто она исходит от реальной веб-страницы браузера, поэтому вы разрешаете вызов API. Опять же, это большая работа, и все же она непогрешима, потому что решительный хакер может просто использовать что-то вроде кукловода для автоматизации реального браузера.