繁体   English   中英

JSP NullPointer StandardWrapperValve[servlets. ]:用于 servlet servlet 的 Servlet.service()。 抛出异常 java.lang.NullPointerException

[英]JSP NullPointer StandardWrapperValve[servlets. ]: Servlet.service() for servlet servlets. threw exception java.lang.NullPointerException

我正在尝试学习如何使用 JSP。 我遇到了一些没有意义的事情,至少在我看来:

当我尝试运行时:

response.getWriter().println(m.getDb().printAll());

我在尝试加载有问题的页面时得到这个:

2014-08-16T03:19:59.789+0200|Warning: StandardWrapperValve[servlets.GUI]: Servlet.service() for servlet servlets.GUI threw exception java.lang.NullPointerException
at servlets.GUI.doGet(GUI.java:39)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:318)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:160)
at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:734)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:673)
at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:99)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:174)
at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:357)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:260)
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:188)
at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:191)
at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:168)
at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:189)
at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:288)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:206)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:136)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:114)
at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:838)
at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:113)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:115)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:55)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:135)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:564)

在 org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:544) 在 java.lang.Thread.run(Thread.java:744)

但是当我运行时:

response.getWriter().println(m.getOut());

输出是正确的。

两者都应该返回相同的结果,因为

class M
{
 String out = "";

 private OjectDAO db = new ObjectDAO()

 public M()
 {
   db.addAll(TextFileLoader(getServletContext().getRealPath("textfile.xml"))); 
 }


 ...
        System.out.println(db.printAll());
        out=db.printAll();
 ...
     public String getOut()
     {
      return out;
     }
 ...
}

class ObjectDAO
{

 ...
 public String printAll()
 {
  String result = "";
  for (WrappedItem item : locDB )
  {
   result = item.toString() + result + "\n";
  }
  return result;
 }
  ...
}

为什么在一种情况下有一个 NullPointer 而在另一种情况下没有?

更多细节:应用程序在 Eclipse Luna 部署的 Glassfish 4 上运行。 操作系统:Debian 应用程序将文本从文件加载到 DAO 并尝试将它们从 DAO 加载到 JSP。 xml 的路径似乎是正确的。

PS:一开始我还以为是BuildPath的问题,因为我之前遇到过类似的问题,后来我在WEB-INF/lib中添加了JDom2.jar就解决了,但是坦白说我不知道​​在哪里可以添加jar这个时间。 有趣的是:即使同时存在这两个问题,STDOUT 的输出也能无缝运行。

附录 1

如上所述,我的问题是:

response.getWriter().println(m.getOut());

工作正常。

response.getWriter().println(m.getDb().printAll());

没有。

这两行都放在 servlet“GUI.java”文件中。 唯一的区别,至少在我看到的 muc 方面是:在第一种情况下,我在通过类 M 中的 String 变量后打印字符串,在第二种情况下,我尝试直接打印它。

这就是所有的区别。

附录 2

添加了完整的堆栈跟踪。

Servlet:通用代码,唯一的区别是

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
{
    System.out.println("Started ");
    response.getWriter().println("<h1> Header1 </h1>");
    response.getWriter().println("<body> Funny body text </body>");
    System.out.println(getServletContext().getRealPath("data.xml"));
    serverJava.Monitor m = new serverJava.Monitor(getServletContext().getRealPath("data.xml"));
    response.getWriter().println("<br> I say:" + m.printHello());
    response.getWriter().println(m.getOut());
    response.getWriter().println(m.getDb().printAll());
}

现在在人们开始之前:以下代码只是为了测试,是否一切正常。 它不是真的留在那里。

public M(String s) 
{
    try
    {
        XMLFileWrapper xml = new XMLFileWrapper(s);
        DataDAO db = new DataDAO();
        db.loadFromHDD(xml.retrieveWrappedRootDataFromXML());
        System.out.println(db.printAll()); <<<< This yealds output
        out=db.printAll(); 
    }catch(Exception e){
        e.printStackTrace();
    }
}

public DataDAO getDb() 
{
    return db;
}

public String getOut()
{
    return out;
}

.

public class DataDAO 
{

    public void loadFromHDD(LinkedList<Item> list)
    {
        locDB.addAll(list);
    }

    public String printAll()
    {
        String result = "";
        for (Item item : locDB )
        {
        result = item.toString() + result + "\n";
        }
    return result;
    }

}

DataDAO 从 JDom2 对象中检索内容......虽然我怀疑它与它有什么关系,但这里是方法:

public LinkedList<Item> retrieveWrappedRootDataFromXML()
{
    LinkedList<Item> result = new LinkedList<Item>();

    for ( Element e : getRoot().getChildren() )
    {
        Item item = new Item();
        item.setInfoId(e.getAttributeValue("id"));
        item.setName(e.getChildText("name"));
        item.setShortName(e.getChildText("short"));
        item.setUser(e.getChildText("user"));
        result.add(item);
    }
    return result;
}

让我们从逻辑上解决这个问题。

以下语句可以(理论上)抛出NullPointerException ,原因如下:

  response.getWriter().println(m.getDb().printAll());
  1. responsenull
  2. response.getWriter()返回null
  3. mnull
  4. m.getDb()null

我们可以从 JSP 规范中删除 1 和 2。 (除非你做了一些真正奇怪的事情......)

我们可以(暂时)根据以下陈述消除 3 个:

  response.getWriter().println(m.getOut());

在(我假设)类似的上下文中工作。 这意味着m不是null (尽管考虑到您的问题中证据的其他不准确之处,我们无法确定......)

这使得 4 成为最可能的原因。 检查您是否正确实现了getDb() 例如,确保它返回的ObjectDAO值不能为null


请注意,我们无法确定其中任何一个,因为您的问题中的代码片段显然是“虚构的”。 它们包含明显的拼写错误,编译器会拒绝。 因此,我们不能相信它们实际上与您的 JSP 中的实际代码非常相似。


更新

既然你已经发布了M类的完整代码,NPE 的原因就跳到我的页面上了!

getDb()方法返回null因为db未初始化。

“但是”我听到你说“它是!!” .

哦不,不是! 您将new DataDAO()分配给局部变量db ,而不是this.db


教训:当无可争辩的逻辑告诉你错误的原因一定是 X 时,争论是没有意义的......

就我而言,我错误地输入了,例如。 productDAO proddao; , 应该是productDAO proddao= new productDAO(); 并且程序有效

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM