![](/img/trans.png)
[英]WARNING: StandardWrapperValve[jsp]: Servlet.service() for servlet jsp threw exception java.lang.NullPointerException glassfish
[英]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 的输出也能无缝运行。
如上所述,我的问题是:
response.getWriter().println(m.getOut());
工作正常。
response.getWriter().println(m.getDb().printAll());
没有。
这两行都放在 servlet“GUI.java”文件中。 唯一的区别,至少在我看到的 muc 方面是:在第一种情况下,我在通过类 M 中的 String 变量后打印字符串,在第二种情况下,我尝试直接打印它。
这就是所有的区别。
添加了完整的堆栈跟踪。
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());
response
为null
。response.getWriter()
返回null
m
为null
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.