【发布时间】:2014-06-06 00:55:12
【问题描述】:
我正在尝试使用 Servlet 进行有关 AJAX 的练习,但出现内部服务器错误。 该程序是创建一个单词列表并将它们保存到一个 XML 文件中。
我的代码如下:
调用 save() 的 HTML
<button onclick="save()">Save keywords</button>
save() 方法:
function save(){
var queryString = "";
for (var i = 0; i < list.length; i++){
if (queryString.length > 0)
{
queryString += "&";
}
queryString += "palavra=";
queryString += list[i];
}
xmlhttp = createRequest(); //creates a XMLHttpRequest
xmlhttp.onreadystatechange = foo;
xmlhttp.open("POST", "SaveXML", true);
xmlhttp.send(queryString);
}
我的 servlet(Eclipse 生成):
package br.com.gabriel;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class SaveXML
*/
@WebServlet(description = "pega a hora do servidor", urlPatterns = { "/SaveXML" })
public class SaveXML extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public SaveXML() {
super();
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String[] words = request.getParameterValues("palavra");
response.setContentType("text/xml");
PrintWriter out = response.getWriter();
out.println("<words>");
for (int i = 0; i < words.length; i++)
{
out.println("<word>");
out.println(words[i]);
out.println("</word>");
}
out.println("</words>");
}
}
我的服务器日志:
GRAVE: Servlet.service() for servlet [br.com.gabriel.SaveXML] in context with path [/Palavras-Chave] threw exception
java.lang.NullPointerException
at br.com.gabriel.SaveXML.doPost(SaveXML.java:40)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:646)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:501)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1040)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:607)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:315)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
提前致谢, 加布里埃尔
【问题讨论】:
-
查看您的服务器日志。向我们展示堆栈跟踪。
-
似乎您没有发送您认为的请求参数。打开浏览器的网络控制台并检查您的请求包含的内容。
-
因此请检查您的 queryString 是否实际包含
palavra -
@GabrielSotero 看到这个答案stackoverflow.com/questions/812925/…
-
您的方法 request.getParameterValues() 必须返回 null。参见API,如果没有找到参数,该方法将返回空值。
标签: java javascript ajax servlets