2012-04-10 2 views
1

나는 JSP로 서블릿과 콩을 통해 jena 쿼리의 데이터를 전달하려고합니다. jsp.file의 bean을 반복 할 때 NPE가 발생합니다. 반복 전에 null이 아닌지 확인하면 jsp.file이 내용없이 표시됩니다.자바 서블릿 3.0 null 포인터 포워딩 jena 쿼리

서블릿

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
    Query query = QueryFactory.read(querySPARQL); 
    // String co = request.getParameter("country"); 
    query = QueryFactory.create(query.toString().replaceAll("\\?country", "a:Netherlands")); 

    QueryExecution qexec = QueryExecutionFactory.sparqlService(endpoint, 
      query); 

    try { 
     ResultSet results = qexec.execSelect(); 
     PlantsBean bean = new PlantsBean(results); 
     HttpSession session = request.getSession(); 
     session.setAttribute("PlantsBean", bean); 


    } finally { 
     qexec.close(); 
    } 
} 

/** 
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 
*/ 
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
    doGet(request, response); 
} 

jsp.file

<% 

     PlantsBean pb = (PlantsBean)session.getAttribute("PlantsBean"); 

     for(PowerPlantInfo ppi : pb) { 
    %> 
    <tr> 


    <td><%=ppi.getFuel() %></td> 


    </tr> 
    <% 
     } 
    %> 
</table> 

오류 메시지 NPE 선 발생

Servlet.service() for servlet [jsp] in context with path [/SemTec1] threw exception 
[java.lang.NullPointerException] with root cause 
java.lang.NullPointerException 
at org.apache.jsp.te_jsp._jspService(te_jsp.java:107) 
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:432) 
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390) 
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169) 
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) 
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) 
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:999) 
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:565) 
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:307) 
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) 
at java.lang.Thread.run(Thread.java:722) 

(... PowerPlantInfo) 대. 그래서 NPE는 콩이 null이라는 것을 말합니다. 그러나 그것은 가능할 수 없습니다. jena 쿼리가 제대로 작동합니다. als 나는 web-inf/classes에 서블릿을 넣으려고했으나 작동하지 않았다. 어제, 내가이 모든 일을 한 번 더 설정했을 때 처음 서버에서 실행했을 때 작동했습니다. 두 번째 시간, 더 이상 일하지 않습니다.

나는 tomcat 7, jdk 7 및 servlets 3.0을 사용하고 있습니다.

미리 감사드립니다.

답변

0

서블릿은 요청을 JSP로 전달하지 않습니다. 그래서 직접 JSP에 액세스하고있는 것 같습니다 (즉, http://yourhost/path/yourfile.jsp).

대신 서블릿이 request.getRequestDispatcher("yourfile.jsp")을 사용하여 JSP로 리디렉션 될 것으로 예상됩니다. 브라우저 (예 : http://yourhost/path/YourServlet)를 사용하여 서블릿을 방문하면 서블릿이 실행되고 결국 JSP로 리디렉션됩니다.