弹簧注释自动装配字段的空指针异常

时间:2019-05-16 12:27:00

标签: java spring autowired

我已经提到了与此类似的所有其他问题,但是似乎没有一种解决方案对我有用。我正在使用spring注解进行自动装配,但为autowired字段获取了空指针异常。下面是代码:

ValidateResouce.java

@Component
@Path("v1")
@Api(value = "v1", description = "Validate API")
public class ValidateResource {

@Autowired
ValidateController validateController;

@GET
@Produces(MediaType.APPLICATION_JSON)
@Path(value = "/validate/{CAN}")
public Response validateCustomerNumber(@PathParam("CAN") String CAN) {
    validateController.validateCustomerNumber(CAN); ---> //getting a null pointer exception here
    return Response.ok().build();
}
}

ValidateController.java

@Component
public class ValidateController {

@Autowired
REPBillingService repBillingService;

public Integer validateCustomerNumber(String CAN) {
    int result;
    if(!repBillingService.isDelinquentCAN(CAN)){
        if(repBillingService.isDemoUser(CAN)){
            result = 5;
        }
        else {
            result = 0;
        }
    }
    else {
        result = getDelinquentStatus(CAN);
    }
    return result;
}

private Integer getDelinquentStatus(String CAN){
    int result;
    DelinquentStatus delinquentStatus = repBillingService.getDelinquentStatus(CAN);
    Integer graceValue = delinquentStatus.getGrace();
    String statusValue = delinquentStatus.getStatus();

    if(delinquentStatus != null) {
        if (graceValue > 0) {
            repBillingService.updateGrace(delinquentStatus.getID());
            result = 1;
        } else if (statusValue == "I") {
            result = 4;
        } else {
            result = 3;
        }
    }
    else {
        result = 3;
    }
    return result;
}
}

REPBillingService.java

@Component
public class REPBillingService {

@Autowired
DelinquentStatus delinquentStatus;

public boolean isDelinquentCAN(String CAN){
    return false;
}

public boolean isDemoUser(String CAN){
    return false;
}

public DelinquentStatus getDelinquentStatus(String CAN){
//        call DelinquentStatus api
    return delinquentStatus;
}

public void updateGrace(Integer ID) {
    // update call
}
}

我在我的 applicationContext.xml

中添加了<context:annotation-config /><context:component-scan base-package...

有人可以告诉我我要去哪里错吗?

错误的堆栈跟踪:

SEVERE: Servlet.service() for servlet [jersey-servlet] in context with path [/isg] threw exception [java.lang.NullPointerException] with root cause
java.lang.NullPointerException
at com.intuit.ptg.lacerte.resource.ValidateResource.validateCustomerNumber(ValidateResource.java:35)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.glassfish.jersey.server.model.internal.ResourceMethodInvocationHandlerFactory$1.invoke(ResourceMethodInvocationHandlerFactory.java:81)
at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher$1.run(AbstractJavaResourceMethodDispatcher.java:144)
at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.invoke(AbstractJavaResourceMethodDispatcher.java:161)
at org.glassfish.jersey.server.model.internal.JavaResourceMethodDispatcherProvider$ResponseOutInvoker.doDispatch(JavaResourceMethodDispatcherProvider.java:160)
at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.dispatch(AbstractJavaResourceMethodDispatcher.java:99)
at org.glassfish.jersey.server.model.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:389)
at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:347)
at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:102)
at org.glassfish.jersey.server.ServerRuntime$2.run(ServerRuntime.java:326)
at org.glassfish.jersey.internal.Errors$1.call(Errors.java:271)
at org.glassfish.jersey.internal.Errors$1.call(Errors.java:267)
at org.glassfish.jersey.internal.Errors.process(Errors.java:315)
at org.glassfish.jersey.internal.Errors.process(Errors.java:297)
at org.glassfish.jersey.internal.Errors.process(Errors.java:267)
at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:317)
at org.glassfish.jersey.server.ServerRuntime.process(ServerRuntime.java:305)
at org.glassfish.jersey.server.ApplicationHandler.handle(ApplicationHandler.java:1154)
at org.glassfish.jersey.servlet.WebComponent.serviceImpl(WebComponent.java:473)
at org.glassfish.jersey.servlet.WebComponent.service(WebComponent.java:427)
at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:388)
at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:341)
at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:228)
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 org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:956)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:436)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1078)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:625)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)

0 个答案:

没有答案
相关问题