gpt4 book ai didi

java - 空指针异常 roster.delete(nationalID);

转载 作者:行者123 更新时间:2023-12-01 11:44:49 25 4
gpt4 key购买 nike

即使我知道NationalID不为空,我的程序仍然给我一个空指针异常。它告诉我 roster.delete(nationalID); line 为空,但是当我在 Netbeans 中运行调试器时,它甚至不会进入删除情况。我还发布了我发现相关的 display.jsp 部分和删除页面 Del.jsp。

名册不为空

Servlet 监听器

public class FoamServletListener implements ServletContextListener {

@Override
public void contextInitialized(ServletContextEvent sce) {

ServletContext sc = sce.getServletContext();

final String path = sc.getRealPath("/WEB-INF/");
Roster.initialize(path + "\\roster.dat");
sc.log("Passed roster initialization");
try {
sc.setAttribute("roster", Roster.getInstance());
} catch (RosterException ex) {
Logger.getLogger(FoamServletListener.class.getName()).log(Level.SEVERE, null, ex);
}
}

@Override
public void contextDestroyed(ServletContextEvent sce) {
sce.getServletContext().removeAttribute("roster");
}

}

初始化方法

    Roster roster;

@Override
public void init() throws ServletException {
super.init();

roster = (Roster) getServletContext().getAttribute("roster");
}

Servlet

String url = "/Del.jsp";

String action = request.getParameter("action");

if (action == null) {
action = "Delete";
}

switch (action) {
case "QueryAthlete":
nationalID = request.getParameter("nationalID");
try {
Athlete athlete = roster.find(nationalID);
// attach athlete and forward to Delete.jsp
request.setAttribute("athlete", athlete);
url = "/Del.jsp";
} catch (RosterException ex) {
Logger.getLogger(EditServlet.class.getName()).log(Level.SEVERE, null, ex);
// Logic to go back to display page
url = "/Display.jsp";

}

break;
case "Delete":

// Get Parameters
nationalID = request.getParameter("nationalID");

try {
roster.delete(nationalID);
url = "/Del.jsp";
} catch (RosterException ex) {
Logger.getLogger(DeleteServlet.class.getName()).log(Level.SEVERE, null, ex);
errMsg = "Cannot delete this Athlete.";
}

request.setAttribute("errMsg", errMsg);
break;

case "Cancel":
url = "/Display.jsp";
break;
}
request.getRequestDispatcher(url).forward(request, response);

显示.jsp

<td><a href="<c:url value ='/DeleteServlet'/>?action=QueryAthlete&nationalID=${athlete.nationalID}">Delete</a></td>

Del.jsp

<form name="name" action="<c:url value='/DeleteServlet'/>" method="POST">
<table border="1" cellpadding="2">
<thead></thead>
<tbody>
<tr>
<td>National ID</td>
<td>${athlete.nationalID}</td>
</tr>
<tr>
<td>First Name</td>
<td>${athlete.firstName}</td>
</tr>
<tr>
<td>Last Name</td>
<td>${athlete.lastName}</td>
</tr>
<tr>
<td>Date Of Birth</td>
<td>${athlete.dateOfBirth}</td>
</tr>
<tr>
<td>Are you sure you want to delete this Athlete?
<input type="submit" value="Delete" name="action" />
<input type="submit" value="Cancel" name="action" /></td>
</tr>
</tbody>
</table>
<c:if test="${errMsg} != null" var="errMsg">
</c:if>
</form>

这是堆栈跟踪:

Info:   action = null
Warning: StandardWrapperValve[DeleteServlet]: Servlet.service() for servlet DeleteServlet threw exception
java.lang.NullPointerException
at java.util.TreeMap.getEntry(TreeMap.java:347)
at java.util.TreeMap.remove(TreeMap.java:603)
at edu.saintpaul.csci2466.foam.roster.Roster.delete(Roster.java:143)
at servlets.DeleteServlet.processRequest(DeleteServlet.java:83)
at servlets.DeleteServlet.doPost(DeleteServlet.java:126)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:707)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilt erChain.java:344)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain. java:214)
at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.jav a:393)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilt erChain.java:256)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain. java:214)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:3 16)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:1 60)
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:415)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:282)
at com.sun.enterprise.v3.services.impl.ContainerMapper$HttpHandlerCallable.call(Con tainerMapper.java:459)
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java :167)
at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:201)
at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:175)
at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:235)
at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.ja va:119)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilter Chain.java:284)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFil terChain.java:201)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain. java:133)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain. java:112)
at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport. java:561)
at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrate gy.java:112)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrat egy.java:117)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadI OStrategy.java:56)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run (WorkerThreadIOStrategy.java:137)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThread Pool.java:565)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPoo l.java:545)
at java.lang.Thread.run(Thread.java:745)

最佳答案

您收到空指针异常不是因为 coz 为 null,而是因为 roster.delete(nationalID); 中的名册为 null

关于

when I run the debugger in Netbeans it is not even going into the delete case.

可能您的代码未正确编译和部署,但异常是您从部署的代码中实际获得的内容

关于java - 空指针异常 roster.delete(nationalID);,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29236865/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com