Java 7, JSP, Spring 3, Apache-Tomcat 7.0.63. Netbeans.
I made changes to an existing JSP file, and changed the backing form object. I went through the JSP to ensure that all references were backed by a field of the correct name in the backing form object.
In the controller, I have a private saveEditedOrNewItem()
; it invokes a method to initialize variables in the model for the page - setCommonModelAttributesForEdit()
. The program bombs when the former calls the latter, throwing a NullPointerException, but I'm not dereferencing anything, I am making no calls within the call to get parameters or anything. One of the parameters is null, but that would not cause NPE by itself.
I have a breakpoint on the first executable line of setCommonModelAttributesForEdit()
; that breakpoint is not reached when the error is triggered (though it executes on a previous invocation and runs to completion without error, so that method is executable).
Here's the code that throws the error:
if (errors.hasErrors()) {
if (entityCode == null || entityCode.equals("")) { entityCode = "Select"; }
Integer entityId = prospectForm.getentityId();
String prospectName = prospectForm.getName();
Object leafNodeFlag = getLeafNodeFlag(request);
Boolean bLeafNodeFlag = (Boolean)leafNodeFlag;
boolean bbLeafNodeFlag = (boolean)bLeafNodeFlag;
Integer logoAttachmentId = prospectForm.getLogoAttachmentId();
ModelMap localModelMap = model;
// the following is line 474 in the stacktrace
setCommonModelAttributesForEdit(localModelMap, entityCode, entityId,
prospectName, bbLeafNodeFlag, prospectForm,
logoAttachmentId);
return prospectEditView;
And here's the error stacktrace:
java.lang.NullPointerException
at com.accesspointinc.crm.prospect.MyFormController.saveEditedOrNewProspect(MyFormController.java:474)
at com.accesspointinc.crm.prospect.MyFormController.saveNewProspect(MyFormController.java:434)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:213)
at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:126)
at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:96)
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:617)
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:578)
at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:923)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:852)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:789)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at com.accesspointinc.commons.filter.SessionTimeoutCookieFilter.doFilter(SessionTimeoutCookieFilter.java:40)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at com.accesspointinc.commons.filter.StatesFilter.doFilter(StatesFilter.java:34)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:614)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.authenticator.SingleSignOn.invoke(SingleSignOn.java:322)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:423)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1079)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:620)
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2516)
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2505)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:722)
I 'flattened' all the parameters passed to setCommonModelAttributesForEdit()
; I have a breakpoint on the call, and can examine all the values being passed in. I even ensured I wouldn't have to cast within the method call. The logoAttachmentId
is null, the rest have non-null values. To repeat, a breakpoint set at the start of setCommonModelAttributesForEdit()
is not hit on this invocation, though it is hit on an earlier invocation.
If I do "step into" instead of "step over" for the call, I end up in an InvocationTargetException constructor with a target of NullPointerException; the call stack indicates (eventually) that I am in a call from SessionTimeoutCookieFilter.doFilter()
; the class is an extension of GenericFilterBean, and the line where it is failing is filterChain.doFilter(request, response);
So it is not your mothers NullPointerException. I am not dereferencing anything in my code, and it halts when I attempt to call a private method within a class in which I'm already executing, so the object for which the method is being referenced is already instantiated. Neither of these are static methods. I have done "clean and compile" multiple times, I have restarted NetBeans, I have rebooted Windows, I have cleaned my browser's cache.
Can anyone suggest what else I might do to find this problem?
Edit: I don't think this qualifies as a duplicate of the question for which it has been closed as a duplicate. Just because a question involves a null pointer does not mean it is a duplicate of the Big "Null Pointer" question.
The cause of this NPE (autobox conversion) was mentioned once in its supposed duplicate, in a comment, and in a different context than it occurred in this question. The current question turned out to be answered by autoboxing as part of parameter passing to a method call; the only mention of it in the Big Question was in an assignment statement. I should have figured it out in less time than it took me, but it stumped a lot of other people, including everyone who read it on SO. (It only got marked as a duplicate after it had been answered.)
I looked through the Big Null Pointer Question before I posted this, and the answer to my question is not there.