在这个超简单的示例中,我无法弄清楚这里发生了什么。
问题摘要:我有一个简单的 servlet,如果我手动驱动它,它似乎运行得很好......通过从浏览器发出它的 URL。我所说的“很好”是指:我可以在浏览器 HTML 页面中看到我在 servlet 响应中写的任何内容。
但是,如果我通过 Ajax 代码发出相同的 URL,则 servlet 可以很好地处理请求,甚至“似乎”可以很好地写出响应……但是,我在 Ajax 客户端代码端看不到任何响应因此在我的浏览器 HTML 页面中都没有。
此外,如果我使我的 XHR 请求同步,浏览器错误控制台会显示以下异常:
错误:未捕获的异常:[异常...“组件返回失败代码:0x80004005 (NS_ERROR_FAILURE) [nsIXMLHttpRequest.send]”nsresult:“0x80004005 (NS_ERROR_FAILURE)”位置:“JS 框架 :: file:///home/sd/ Desktop/test.html :: callServlet :: line 35" data: no]
环境:
浏览器:火狐3.5.3
Servlet 容器:Tomcat 6.0.20
操作系统:Linux / Fedora 11
阿贾克斯代码:
<!-- 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;
}
编辑:
包括结果:这是我看到的,例如我的 debugHtmlId 元素的 innerHTML 的值。
readyState='1' readyState='1' readyState='2' status='0' responseText='' | readyState='4' 状态='0' responseText='' |
奇怪的行为:还要注意我的 readystatechange 处理程序正在重新输入!我的意思是,我期待看到 readyState='...' status='...' responseText='...' 每次状态变化的三元组...