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

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

Шрифт:

Пример 18.3. Синтаксический анализ НТТР-ответа

// Выполняет запрос HTTP GET на получение содержимого по указанному URL-адресу.

// При получении ответа он передается функции обратного вызова

// как разобранный объект XML-документа, объект JS0N или строка,

function get(url, callback) {

var request = new XMLHttpRequest; // Создать новый запрос

request.open("GET", url); // Указать URL-адрес ресурса

request.onreadystatechange = function { // Определить обработчик события

// Если запрос был выполнен и увенчался успехом

if (request.readyState === 4 && request.status === 200) {

// Определить тип ответа

var type = request.getResponseHeader("Content-Type");

// Проверить тип, чтобы избежать в будущем передачи ответа

// в виде документа в формате HTML

if (type.index0f("xml") !== -1 && request.responseXML)

callback(request.responseXML); // Объект XML

else

if (type === "application/json")

callback(JSON.parse(request.responseText)); // Объект JSON

else

callback(request.responseText); // Строка

}

};

request.send(null); // Отправить запрос

}

Функция в примере 18.3 проверяет заголовок «Content-Type» ответа и обрабатывает ответы типа «application/json» особым образом. Другими типами ответов, которые может потребоваться «декодировать» особо, являются «application/Java-Script» и «text/JavaScript». С помощью объекта

XMLHttpRequest
можно запрашивать сценарии на языке JavaScript и затем выполнять их с помощью глобальной функции
eval
(раздел 4.12.2). Однако в этом нет никакой необходимости, потому что возможностей самого элемента
<script>
вполне достаточно, чтобы загрузить и выполнить сценарий. Вернитесь к примеру 13.4, держа в уме, что элемент
<script>
может выполнять HTTP-запросы к другим серверам, запрещенные в прикладном интерфейсе
XMLHttpRequest
.

В ответ на HTTP-запросы веб-серверы часто возвращают двоичные данные (например, файлы изображений). Свойство

responseText
предназначено только для текстовых данных и не позволяет корректно обрабатывать ответы с двоичными данными, даже если использовать метод
charCodeAt
полученной строки. Спецификация «ХНН2» определяет способ обработки ответов с двоичными данными, но на момент написания этих строк производители броузеров еще не реализовали его. Дополнительные подробности приводятся в разделе 22.6.2.

Для корректного декодирования ответа сервера необходимо, чтобы сервер отправлял заголовок «Content-Type» с правильным значением MIME-типа ответа. Если, к примеру, сервер отправит XML-документ, не указав соответствующий MIME-тип, объект

XMLHttpRequest
не произведет синтаксический анализ ответа и не установит значение свойства
responseXML
. Или, если сервер укажет неправильное значение в параметре «charset» заголовка «Content-Type», объект
XMLHttpRequest
декодирует ответ с использованием неправильной кодировки и в свойстве
responseText
могут оказаться ошибочные символы.

Спецификация «ХНН2» определяет метод

overrideMimeType,
предназначенный для решения этой проблемы, и он уже реализован в некоторых броузерах. Если необходимо определить MIME-тип, лучше подходящий для веб-приложения, чем возвращаемый сервером, можно перед вызовом метода
send
передать методу
overrideMimeType
свой тип - это заставит объект
XMLHttpRequest
проигнорировать заголовок «Content-Type» и использовать указанный тип. Предположим, что необходимо загрузить XML-файл, который планируется интерпретировать как простой текст. В этом случае можно воспользоваться методом
overrideMimeType,
чтобы сообщить объекту
XMLHttpRequest
, что он не должен выполнять синтаксический анализ файла и преобразовывать его в объект XML-документа:

// Не обрабатывать ответ, как XML-документ

request.overrideMimeType("text/plain; charset=utf-8")

18.1.3. Оформление тела запроса

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

  • Читать дальше
  • 1
  • ...
  • 325
  • 326
  • 327
  • 328
  • 329
  • 330
  • 331
  • 332
  • 333
  • 334
  • 335
  • ...

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

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

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

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