Я не могу понять, что здесь происходит в этом ультра простом примере.
Описание проблемы: У меня есть простой сервлет, который, кажется, работает нормально, если я вожу его вручную ..., выдавая его URL из браузера. Под «просто отлично» я подразумеваю: я вижу в браузере HTML-страницу все, что пишу в ответе сервлета.
Однако , если я выдаю тот же URL-адрес с помощью кода Ajax, сервлет обрабатывает запрос нормально и даже «кажется» выписывает ответ нормально ... но, просто я этого не делаю увидеть любой ответ на стороне кода Ajax-клиента и, следовательно, ни на HTML-странице моего браузера.
Далее , если я сделаю мой запрос XHR синхронным, в консоли ошибок браузера отобразится следующее исключение:
Ошибка: необработанное исключение: [Exception ... »Компонент возвратил код ошибки: 0x80004005 (NS_ERROR_FAILURE) [nsIXMLHttpRequest.send]« nsresult: «0x80004005 (NS_ERROR_FAILURE)» расположение: «JS frame :: file: / //home/sd/Desktop/test.html :: callServlet :: line 35 "data: no]
Окружающая среда:
Браузер: Firefox 3.5.3
Контейнер сервлетов: Tomcat 6.0.20
ОС: Linux / Fedora 11
Код Ajax:
<!-- test.html -->
<html>
<head>
<script>
var req;
function $(id) {
return document.getElementById(id);
}
function servletCallback() {
var field = $("debugHtmlId");
field.innerHTML += "readyState='" + req.readyState + "'<br> ";
field.innerHTML += "status='" + req.status + "'<br> ";
field.innerHTML += "responseText='" + req.responseText + "' | <br> ";
}
req = new XMLHttpRequest();
req.onreadystatechange = servletCallback;
function callServlet() {
// With async mode off, I get the
// Exception listed above.
// req.open("GET", "http://localhost:8080/aaa/bbb?f=test", false);
req.open("GET", "http://localhost:8080/aaa/bbb?f=test", true);
req.send(null);
}
</script>
</head>
<body>
<input id="callserv" type="submit" value="Call Servlet" onclick="callServlet();" />
<span id="debugHtmlId"></div>
</body>
</html>
Код сервлета:
// servlet code
public class MyServlet extends HttpServlet {
public void doGet(HttpServletRequest req, HttpServletResponse rsp)
throws ServletException, IOException {
rsp.setContentType("text/html");
String val = req.getParameter("f");
if(val.equals("test")) {
// Increment value.
++_count;
// Return value.
PrintWriter out = rsp.getWriter();
out.printf("%d\n", _count);
out.close();
// This shows up fine in servlet log.
System.out.printf("%d\n", _count);
}
}
// This variable is incremented and returned on each call to doGet().
private int _count = 0;
}
EDIT:
Включая результат: вот что я вижу, например, как значение моего innerHTML моего элемента debugHtmlId.
readyState = '1'
readyState = '1'
readyState = '2'
статус = '0'
responseText = '' |
readyState = '4'
статус = '0'
responseText = '' |
Странное поведение: обратите внимание также, что мой обработчик readystatechange получает повторный ввод ! Я имею в виду, я ожидал увидеть триады readyState = '...' status = '...' responseText = '...' для каждого изменения состояния ...