I try to get string from servlet and dispaly them in the web page, but get err likes below. How can I fix this err? does this caused by servlet coding or ajax coding? any idea to solve it? I use action of form to give data to the back-end and use ajax to receive feedback from servlet. any better choice?
SEVERE: Servlet.service() for servlet [com.tsinghua.QueryServlet] in context with path [/ReportingFunction] threw exception
java.lang.NumberFormatException: null
at java.base/java.lang.Integer.parseInt(Integer.java:614)
at java.base/java.lang.Integer.parseInt(Integer.java:770)
at com.tsinghua.QueryServlet.doGet(QueryServlet.java:39)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:543)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:690)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:615)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:818)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1627)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.base/java.lang.Thread.run(Thread.java:834)
There are my ajax code
<script>
$(document).ready(function(){
$.ajax({
url: "http://localhost:8080/ReportingFunction/QueryServlet",
type: "GET",
dataType: "json",
success: function(NewArray){
showData(NewArray);
},
error: function(msg){
alert("ajax连接异常!!!!:"+msg);
}
});
});
</script>
and my servlet code
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
String GetName = request.getParameter("name");
int GetAgeFrom = Integer.parseInt(request.getParameter("from"));
int GetAgeTo = Integer.parseInt(request.getParameter("to"));
PrintWriter respWritter=response.getWriter();
try {
String filePath = this.getServletContext().getRealPath("/WEB-INF/data.json");
String jsonStr = JsonUtils.readJsonFile(filePath);
JSONArray jsonArray = JSONArray.fromObject(jsonStr);
//System.out.print(jsonArray);
JSONArray NewArray = new JSONArray();
for(int i=0;i<jsonArray.size();i++)
{
JSONObject object = (JSONObject) jsonArray.get(i);
String JsonName= object.getString("name");
//System.out.print(JsonName);
int JsonAge=object.getInt("age");
// System.out.print(JsonAge);
if(GetAgeFrom <= JsonAge && JsonAge <= GetAgeTo)
{
if(JsonName.equals(GetName))
{
NewArray.add(object);
String result=object.toString();
//System.out.print(result);
//respWritter.append(result);
}
else if (GetName.equals(""))
{
NewArray.add(object);
String result=object.toString();
request.setAttribute("result", result);
//System.out.print(result);
// respWritter.append(result);
}
}
};
respWritter.append(NewArray.toString());
respWritter.write(NewArray.toString());
}
catch (Exception ex) {
ex.printStackTrace();
}
}