Я пытаюсь получить XML-ответ, используя ajax-вызовы REST API eXist DB (1 ).
Google Chrome выдает мне следующую ошибку консоли:
XMLHttpRequest cannot load XMLHttpRequest cannot load http://localhost:8080/exist/rest/db/movies?_query=%2Fmovies. Origin null is not allowed by Access-Control-Allow-Origin Origin null is not allowed by Access-Control-Allow-Origin
Хотя Firebug в Firefox выдает следующую ошибку консоли:
GET http://localhost:8080/exist/rest/db/movies?_query=%2Fmovies 200 OK X 35ms jquery.min.js(line 18)
Вот часть кода ajax:
$.ajax({
type: 'GET',
dataType: 'xml',
url: 'http://localhost:8080/exist/rest/db/movies',
data: {
_query: _query_value,
_key: _key_value,
_indent: _indent_value,
_encoding: _encoding_value,
_howmany: _howmany_value,
_start: _start_value,
_wrap: _wrap_value,
_source: _source_value,
_cache: _cache_value
},
success: function(resp){
alert("Resp OK!");
console.log(resp);
},
error: function(hqXHR, textStatus, errorThrown){
var x=0;
alert("fail0 " + hqXHR + " " + textStatus + " " + errorThrown);
}
});
Я прочитал некоторые связанные вопросы по этой же проблеме, но мне не повезло ни с одним из решений, которые я пробовал.
Доступ к файлу index.html, содержащему приведенный выше сегмент кода ajax, осуществляется с моего локального компьютера следующим образом:
file:///.../index.html
Я попытался выполнить хром следующим образом:
chrome.exe --allow-file-access-from-files
Кроме того, я попытался развернуть файл на онлайн-хостинге, чтобы он находился по адресу
http://www..com/index.html
. Самое близкое решение, которое у меня было, состояло в том, чтобы изменить тип данных с xml на jsonp. Ответ получен, но так как ожидается xml, то ошибка стала связана с парсингом, думаю,со следующим оператором, возвращенным консолью Google Chrome:
Uncaught SyntaxError: Unexpected token <
и консоль Firebug:
XML can't be the whole program
[Break On This Error]
movies...3302057 (line 528, col 15)
Возвращаясь к моему вопросу, как я могу правильно получить XML-документ через базу данных eXist? Что я делаю не так?
С нетерпением жду вашей помощи. Я новичок в веб-разработке, и у меня заканчиваются идеи.
Заранее спасибо!
Другие примечания:
Jquery.min.js, который я использую, находится по адресуhttp://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js
URI http://localhost:8080/exist/rest/db/movies?_query=%2Fmovies
работает при прямом вводе в любом браузере.
Ссылка:
(1) - http://www.exist-db.org/exist/devguide_rest.xml;jsessionid=e7096vtg4l7gmocouhe6zhle
Обновления (1 )Кажется, мне удалось избавиться от проблемы CORS, запустив eXist DB в качестве сервера следующим образом :bin/server.sh (в UNIX )или bin\server.bat (в Windows ).
Однако сейчас я столкнулся с проблемой другого типа. Я получаю следующую ошибку в консоли Google Chrome, используя jquery.js:
GET http://localhost:8080/exist/rest/db/movies?_query=%2Fmovies jquery.js:8240
jQuery.ajaxTransport.send jquery.js:8240
jQuery.extend.ajax jquery.js:7719
(anonymous function) index.html:43
jQuery.event.dispatch jquery.js:3332
jQuery.event.add.elemData.handle.eventHandle jquery.js:2941
и используя jquery.min.js:
GET http://localhost:8080/exist/rest/db/movies?_query=%2Fmovies jquery.min.js:18
f.support.ajax.f.ajaxTransport.send jquery.min.js:18
f.extend.ajax jquery.min.js:18
(anonymous function) index.html:43
f.event.handle jquery.min.js:17
f.event.add.i.handle.k jquery.min.js:16
Что означает ошибка? Какую часть моего кода я делаю неправильно?
(2 )Обновление 1, видимо, лишняя проблема, с которой я столкнулся. Режим сервера не работал с моей машиной, поэтому появились ошибки, указанные выше.