У меня есть простой скрипт, пытающийся получить доступ к общедоступным данным, предоставленным USGS в качестве конечной точки JSON. Прямо сейчас скрипт возвращает код статуса HTTP 0: 'undefined', который, как я понимаю, является общим кодом статуса, который может означать множество вещей. Урезанный код, который я пытался проверить:
<script type = "text/javascript">
$('#query').click(function() {
var jqxhr = $.ajax({
url: 'https://waterservices.usgs.gov/nwis/iv/?format=json&sites=08170500¶meterCd=00060',
type: 'get',
dataType: 'json',
beforeSend: function(xhr) {
xhr.setRequestHeader('Content-Type', 'application/json');
xhr.setRequestHeader('Accept', 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8');
xhr.setRequestHeader('Accept-Encoding', 'gzip, deflate, br');
xhr.setRequestHeader('Accept-Language' , 'en-US,en;q=0.5');
xhr.setRequestHeader('Connection' , 'keep-alive');
xhr.setRequestHeader('Host' , 'waterservices.usgs.gov');
xhr.setRequestHeader('Upgrade-Insecure-Requests' , '1');
xhr.setRequestHeader('User-Agent', 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.92 Safari/537.36');
}
})
.done(function () {
alert( "success");
})
.fail(function(jqXHR, textStatus, errorThrown) {
alert("failure");
$('#sitedesc').text(jqXHR.status + ' - ' + jqXHR.responseText);
})
.always(function() {
alert("complete");
});
});
</script>
Я сузил, что функция beforeSend, по-видимому, вызывает проблему, что заставило меня подумать, что это проблема CORS. Но в документации служб водоснабжения USGS прямо указано, что служба поддерживает CORS (https://waterservices.usgs.gov/rest/IV-Service.html#CORS).
Удаление заголовков запроса также не является вариантом, поскольку это возвращает запрещенный код состояния 403, что является причиной, по которой сотрудники USGS предположили, что мне нужно было предоставить заголовки в первую очередь.
У кого-нибудь есть понимание? Спасибо!
Отказ от ответственности: я не инженер-программист, и JavaScript не моя сильная сторона :)
Хм, это странно. Здесь, на моей рабочей машине, если я удалю обработчик beforeSend, я получу 403 запрещенную ошибку. Для проверки я загрузил скрипт на внешний веб-сервер, и он сработал. Должно быть что-то с моей рабочей сетью. Спасибо.
Без проблем. Вы пробовали просто открыть URL без использования скрипта? Как я уже сказал, поскольку это запрос GET, он имеет тот же эффект, что и использование сценария, но часто может помочь вам понять, в чем проблема.
Да, запуск его непосредственно с URL-адреса был успешным из getgo, поэтому я смог понять, что это как-то связано с JS, выполняющим запрос в браузере. Я получаю ошибку 403 при выполнении скрипта в Chrome / Edge / Firefox, но он работает в IE. Похоже, это какая-то настройка или протокол сетевой безопасности в нашей рабочей сети, и наша сетевая группа изучает это.



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Я удалил обработчик
beforeSend, и он работает нормально. Если вы можете открыть URL-адрес в своем браузере (что вы можете), то вы знаете, что обычный метод GET работает нормально, без каких-либо конкретных заголовков.