Вход/Регистрация
JavaScript. Подробное руководство, 6-е издание
вернуться

Флэнаган Дэвид

Шрифт:

Спецификация «ХНН2» позволяет выполнять междоменные запросы к другим веб-сайтам, указанным в заголовке «CORS» (Cross-Origin Resource Sharing) HTTP-ответа. На момент написания этих строк текущие версии броузеров Firefox, Safari и Chrome поддерживали заголовок «CORS», а версия IE8 поддерживала собственный объект

XDomainRequest
, который здесь не описывается. Веб-программисту при этом не придется делать ничего особенного: если броузер поддерживает заголовок «CORS» для объекта
XMLHttpRequest
и если вы пытаетесь выполнить междоменный запрос к веб-сайту, доступ к которому разрешен в заголовке «CORS», политика общего происхождения просто не будет препятствовать выполнению междоменного запроса, и все будет работать само собой.

Хотя при наличии поддержки заголовка «CORS» не требуется предпринимать какие-то дополнительные шаги для выполнения междоменных запросов, тем не менее имеются некоторые детали, касающиеся безопасности, которые желательно понимать. Во-первых, при передаче имени пользователя и пароля методу

open
объекта
XMLHttpRequest
они не будут передаваться в междоменных запросах (в противном случае это дало бы злоумышленникам возможность взламывать пароли). Кроме того, междоменные запросы обычно не допускают включение в них никакой другой информации, подтверждающей подлинность пользователя: cookies и HTTP-лексемы аутентификации обычно не передаются в составе запроса, а любые cookies, полученные в результате выполнения междоменного запроса, уничтожаются. Если для выполнения междоменного запроса требуется выполнить аутентификацию пользователя, перед вызовом метода
send
следует установить свойство
withCredentials
объекта
XMLHttpRequest
в значение true. Проверка наличия свойства
withCredentials
позволит определить наличие поддержки заголовка «CORS» в броузере, хотя обычно этого не требуется.

В примере 18.13 приводится ненавязчивый JavaScript-код, использующий объект

XMLHttpRequest
для выполнения HEAD-запросов HTTP с целью получения информации о типах, размерах и датах последнего изменения ресурсов, на которые ссылаются элементы
<а>.
HEAD-запросы выполняются по требованию, а полученная информация отображается во всплывающих подсказках. В этом примере предполагается, что информация не будет доступна для междоменных ссылок, тем не менее в броузерах с поддержкой заголовка «CORS» все равно будут выполняться попытки получить ее.

Пример 18.13. Получение информации о ссылках с помощью HEAD-запросов при наличии поддержки заголовка «CORS»

/**

* linkdetails.js

*

* Этот модуль в стиле ненавязчивого JavaScript отыскивает все элементы <а>

* с атрибутом href и без атрибута title, и добавляет в них обработчики

* события onmouseover. Обработчик события выполняет HEAD-запрос с помощью

* объекта XMLHttpRequest, чтобы получить сведения о ресурсе, на который

* указывает ссылка, и сохраняет эту информацию в атрибуте title ссылки,

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

*/

whenReady(function {

// Поддерживается ли возможность выполнения междоменных запросов?

var supportsCORS = (new XMLHttpRequest).withCredentials !== undefined;

// Обойти в цикле все ссылки в документе

var links = document.getElementsByTagName('a');

for(var і = 0; і < links.length; і++) {

var link = links[і];

if (!link.href) continue; // Пропустить якоря, не являющиеся ссылками

if (link.title) continue; // Пропустить ссылки с атрибутом title

// Если это междоменная ссылка

if (link.host!==location.host || link.protocol !== location.protocol)

{

link.title = "Ссылка на другой сайт"; // Предполагается, что нельзя

// получить дополнительную информацию

if (!supportsCORS) continue; // Пропустить, если заголовок

// C0RS не поддерживается

// Иначе есть надежда получить больше сведений о ссылке. Поэтому регистрируем

// обработчик события, который предпримет попытку сделать это.

  • Читать дальше
  • 1
  • ...
  • 333
  • 334
  • 335
  • 336
  • 337
  • 338
  • 339
  • 340
  • 341
  • 342
  • 343
  • ...

Ебукер (ebooker) – онлайн-библиотека на русском языке. Книги доступны онлайн, без утомительной регистрации. Огромный выбор и удобный дизайн, позволяющий читать без проблем. Добавляйте сайт в закладки! Все произведения загружаются пользователями: если считаете, что ваши авторские права нарушены – используйте форму обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

Подпишитесь на рассылку: