2014-10-16 97 views
2

我正在阅读一本书来学习ajax,而且我陷入了僵局,因为我的JavaScript中没有在alert中显示我的Servlet响应(只是文本)。当按钮被点击时,它会调用JavaScript函数,然后异步发送一个http请求。为什么servlet响应没有在我的JavaScript中显示

我不明白为什么字符串没有显示在响应中。感谢任何人都可以解决这个问题。

编辑:另外,发送“获取”请求后,我得到一个200的状态代码。当我看着控制台下的萤火虫时,我看到带有200个状态码的Get请求。有3个选项卡 - Params,Headers和XML。在参数下,我看到了我在请求中发送的虚拟参数。在标题下有2个节点 - 响应标题和请求标题。当我展开Response Header节点时,我看到一个名为content-length的东西,后面跟着一个0。这是否意味着我的回应中没有任何内容?

这里是我的HTML

<html> 
<head> 
    <title>Boards 'R' Us</title> 
    <link rel="stylesheet" type="text/css" href="boards.css" media="screen" /> 
    <script type="text/javascript" src="ajax.js"> </script> 
    <script type="text/javascript" src="text-utils.js"> </script> 
    <script type="text/javascript" src="boards.js"> </script> 
</head> 

<body> 
    <h1>Boards 'R' Us :: How Much Butt We're Kicking</h1> 
    <div id="boards"> 
    <table> 
    <tr><th>Snowboards Sold</th> 
    <td><span id="boards-sold">1672</span></td></tr> 
    <tr><th>What I Sell 'em For</th> 
    <td>$<span id="boards-price">249.95</span></td></tr> 
    <tr><th>What it Costs Me</th> 
    <td>$<span id="boards-cost">84.22</span></td></tr> 
    </table> 
    <table> 
    <tr><th>Boots Sold</th> 
    <td><span id="boots-sold">312</span></td></tr> 
    <tr><th>What I Sell 'em For</th> 
    <td>$<span id="boots-price">175.47</span></td></tr> 
    <tr><th>What it Costs Me</th> 
    <td>$<span id="boots-cost">54.23</span></td></tr> 
    </table> 
    <table> 
    <tr><th>Bindings Sold</th> 
    <td><span id="bindings-sold">82</span></td></tr> 
    <tr><th>What I Sell 'em For</th> 
    <td>$<span id="bindings-price">146.92</span></td></tr> 
    <tr><th>What it Costs Me</th> 
    <td>$<span id="bindings-cost">98.03</span></td></tr> 
    </table> 
    <h2>Cash for the Slopes: 
    $<span id="cash">318936.42</span></h2> 
    <form> 
    <input value="Show Me the Money" type="button" 
      onClick="getNewTotals();" /> 
    </form> 
    </div> 
</body> 
</html> 

和我的JavaScript

function getNewTotals() { 
    console.log("Getting new totals"); 
    var url = "boards.do"; 
    url = url + "?dummy=" + new Date().getTime(); 
    request.open("GET", url, true); 
    request.onreadystatechange = updatePage; 
    request.send(null); 
} 

function updatePage() { 
    if (request.readyState == 4) { 
     if (request.status == 200) { 
      var reply = request.responseText; 
      alert("returned: " + reply); 
     } else { 
      alert("Error! Request status = " + request.status); 
     } 
    } 
} 

和我的servlet

import java.io.IOException; 
import java.io.PrintWriter; 
import java.util.logging.Level; 
import java.util.logging.Logger; 

import javax.servlet.ServletException; 
import javax.servlet.annotation.WebServlet; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 

import com.gmail.gmjord.controller.BoardSalesController; 

/** 
* Servlet implementation class BoardSalesController 
*/ 
//@WebServlet("/BoardSalesController") 
public class BoardSalesController extends HttpServlet { 
    private static final long serialVersionUID = 1L; 
    private static final Logger LOGGER = Logger.getLogger(BoardSalesController.class.getClass().getName()); 
    private static final Level INFO = Level.INFO; 
    private static final Level[] LEVELS = {Level.SEVERE, Level.WARNING, Level.INFO, Level.CONFIG, 
     Level.FINE, Level.FINER, Level.FINEST}; 

    /** 
    * @see HttpServlet#HttpServlet() 
    */ 
    public BoardSalesController() { 
     super(); 
     // TODO Auto-generated constructor stub 
    } 

    /** 
    * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) 
    */ 
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
     // TODO Auto-generated method stub 
     LOGGER.log(INFO, "in doGet()"); 
     String info = request.getParameter("dummy"); 
     LOGGER.log(INFO, "Request info: " + info); 
     response.setContentType("text/plain"); 
     response.setCharacterEncoding("UTF-8"); 
     String reply = "Do you see this?"; 
     response.getWriter().write(reply); 


    } 

    /** 
    * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 
    */ 
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
     // TODO Auto-generated method stub 
    } 

} 
+0

那么,发生了什么*在调试器中运行它并观察网络流量。在updatePage中放置一个断点,看看它是否被调用以及如何调用。 – Malvolio 2014-10-16 21:43:17

+0

您可以使用Chrome或Firefox开发工具甚至是萤火虫来检查XMLHttpRequest流量,并检查它会发生什么。您还可以检查除200以外的其他响应状态(也许正在生成404或500错误) – 2014-10-16 22:31:01

+0

@Malvolio,感谢您提醒我,我可以调试JavaScript - 在此处仍是新的。我调试它在firebug和request.responseText显示“”的值。所以我认为Servlet不会正确地发送响应。仍在调查。 – mitchj 2014-10-17 11:23:35

回答

1

我明白你正确地调用servlet并获得与响应http-header status = 200,但是你没有收到str内容,不是吗?

然后我想你必须致电flush()作者提交回应。如果您在javax.servlet.ServletResponsedocumentation这是你可以看到这个的javax.servlet.http.HttpServletResponse接口检查getWriter():在PrintWriter的调用flush()

提交的响应。

然而,这通常是没有必要的,因为servlet container为你做的,但是你的情况似乎并不那么这段代码在doGet方法上你的servlet尝试:

String reply = "Do you see this?"; 
PrintWriter writer = response.getWriter(); 
writer.write(reply); 
writer.flush(); 

希望这有助于

+0

我试过这种方式,它没有帮助。我不确定发生了什么事,但经过几个小时试图弄清楚它神秘地开始工作。 我有其他神秘的事情,试图运行的Web应用程序有时不会加载所有的JavScripts等,但然后神奇地开始再次做。 我正在投票试图帮助我!谢谢!!我希望我可以投票。 – mitchj 2014-10-17 12:15:09

+0

感谢你':)'。起初,这对我来说听起来很奇怪,因为通常servlet容器会执行'flush()',但是在场景后面可能会发生某些事情,所以我试着回答。当奇怪的事情开始发生时,这很让人伤心,也许你可以尝试一下全新安装你的web容器':)'。 – albciff 2014-10-17 12:33:24