Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/14.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 使用jackson处理器spring mvc 3.1时出现空指针异常_Java_Json_Spring Mvc_Jackson - Fatal编程技术网

Java 使用jackson处理器spring mvc 3.1时出现空指针异常

Java 使用jackson处理器spring mvc 3.1时出现空指针异常,java,json,spring-mvc,jackson,Java,Json,Spring Mvc,Jackson,我有下面的pojo,我正试图使用spring对jackson处理器的支持对其进行序列化和反序列化,下面是我的pojo类 public class Contract { String term; private List<Payment> paymentList=new ArrayList<Payment>(); public String getTerm() { return term; } public void setTerm(String term) {

我有下面的pojo,我正试图使用spring对jackson处理器的支持对其进行序列化和反序列化,下面是我的pojo类

public class Contract {
String term;
private List<Payment> paymentList=new ArrayList<Payment>();
public String getTerm() {
    return term;
}
public void setTerm(String term) {
    this.term = term;
}
public List<Payment> getPaymentList() {
    return paymentList;
}
public void setPaymentList(List<Payment> paymentList) {
    this.paymentList = paymentList;
}

}
堆栈跟踪为

java.lang.NullPointerException
at org.springframework.samples.mvc.ajax.json.FormatAnnotationIntrospector.findDeserializer(FormatAnnotationIntrospector.java:33)
at org.codehaus.jackson.map.AnnotationIntrospector$Pair.findDeserializer(AnnotationIntrospector.java:1058)
at org.codehaus.jackson.map.deser.BasicDeserializerFactory.findDeserializerFromAnnotation(BasicDeserializerFactory.java:462)
at org.codehaus.jackson.map.deser.BeanDeserializerFactory.constructSettableProperty(BeanDeserializerFactory.java:606)
at org.codehaus.jackson.map.deser.BeanDeserializerFactory.addBeanProps(BeanDeserializerFactory.java:460)
at org.codehaus.jackson.map.deser.BeanDeserializerFactory.buildBeanDeserializer(BeanDeserializerFactory.java:149)
at org.codehaus.jackson.map.deser.BeanDeserializerFactory.createBeanDeserializer(BeanDeserializerFactory.java:116)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createDeserializer(StdDeserializerProvider.java:342)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createAndCache2(StdDeserializerProvider.java:264)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createAndCacheValueDeserializer(StdDeserializerProvider.java:244)
at org.codehaus.jackson.map.deser.StdDeserializerProvider.findValueDeserializer(StdDeserializerProvider.java:111)
at org.codehaus.jackson.map.deser.StdDeserializer.findDeserializer(StdDeserializer.java:482)
at org.codehaus.jackson.map.deser.BeanDeserializer.resolve(BeanDeserializer.java:271)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._resolveDeserializer(StdDeserializerProvider.java:348)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createAndCache2(StdDeserializerProvider.java:303)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createAndCacheValueDeserializer(StdDeserializerProvider.java:244)
at org.codehaus.jackson.map.deser.StdDeserializerProvider.findValueDeserializer(StdDeserializerProvider.java:111)
at org.codehaus.jackson.map.deser.BasicDeserializerFactory.createCollectionDeserializer(BasicDeserializerFactory.java:182)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createDeserializer(StdDeserializerProvider.java:332)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createAndCache2(StdDeserializerProvider.java:264)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createAndCacheValueDeserializer(StdDeserializerProvider.java:244)
at org.codehaus.jackson.map.deser.StdDeserializerProvider.findValueDeserializer(StdDeserializerProvider.java:111)
at org.codehaus.jackson.map.deser.StdDeserializer.findDeserializer(StdDeserializer.java:482)
at org.codehaus.jackson.map.deser.BeanDeserializer.resolve(BeanDeserializer.java:271)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._resolveDeserializer(StdDeserializerProvider.java:348)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createAndCache2(StdDeserializerProvider.java:303)
at org.codehaus.jackson.map.deser.StdDeserializerProvider._createAndCacheValueDeserializer(StdDeserializerProvider.java:244)
at org.codehaus.jackson.map.deser.StdDeserializerProvider.findValueDeserializer(StdDeserializerProvider.java:111)
at org.codehaus.jackson.map.deser.StdDeserializerProvider.findTypedValueDeserializer(StdDeserializerProvider.java:127)
at org.codehaus.jackson.map.ObjectMapper._findRootDeserializer(ObjectMapper.java:2046)
at org.codehaus.jackson.map.ObjectMapper._readMapAndClose(ObjectMapper.java:1980)
at org.codehaus.jackson.map.ObjectMapper.readValue(ObjectMapper.java:1331)
at org.springframework.http.converter.json.MappingJacksonHttpMessageConverter.readInternal(MappingJacksonHttpMessageConverter.java:124)
at org.springframework.http.converter.AbstractHttpMessageConverter.read(AbstractHttpMessageConverter.java:153)
at com.budco.vsc.jsonmapping.ContractJsonBindingTests.testAnnotationDrivenJsonConversion(ContractJsonBindingTests.java:59)
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.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
at org.junit.runners.BlockJUnit4ClassRunner.runNotIgnored(BlockJUnit4ClassRunner.java:79)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:71)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:49)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
注意:-如果我要从POJO中删除list属性(paymentList),则没有问题。这意味着当POJO内容包含一些集合属性时,上述内容不起作用。如果任何人有任何想法,请帮助我

编辑: 支付类

public class Payment {

private BigDecimal amount;
private String payType;
private String transactionType;
private String chargeOrCancelFlag;
private String type;
private String authCode;
private Date authRequestDate;
private String authStatus;
private String authTransactioncode;
private SystemUser systemUser;
private String mailOrEmailInvoice;
private String monthlyBillOnDay;
private CreditCard creditCard;


public BigDecimal getAmount() {
    return amount;
}
public void setAmount(BigDecimal amount) {
    this.amount = amount;
}
public String getPayType() {
    return payType;
}
public void setPayType(String payType) {
    this.payType = payType;
}
public String getTransactionType() {
    return transactionType;
}
public void setTransactionType(String transactionType) {
    this.transactionType = transactionType;
}
public String getChargeOrCancelFlag() {
    return chargeOrCancelFlag;
}
public void setChargeOrCancelFlag(String chargeOrCancelFlag) {
    this.chargeOrCancelFlag = chargeOrCancelFlag;
}
public String getType() {
    return type;
}
public void setType(String type) {
    this.type = type;
}
public String getAuthCode() {
    return authCode;
}
public void setAuthCode(String authCode) {
    this.authCode = authCode;
}
public Date getAuthRequestDate() {
    return authRequestDate;
}
public void setAuthRequestDate(Date authRequestDate) {
    this.authRequestDate = authRequestDate;
}
public String getAuthStatus() {
    return authStatus;
}
public void setAuthStatus(String authStatus) {
    this.authStatus = authStatus;
}
public String getAuthTransactioncode() {
    return authTransactioncode;
}
public void setAuthTransactioncode(String authTransactioncode) {
    this.authTransactioncode = authTransactioncode;
}
public SystemUser getSystemUser() {
    return systemUser;
}
public void setSystemUser(SystemUser systemUser) {
    this.systemUser = systemUser;
}
public String getMailOrEmailInvoice() {
    return mailOrEmailInvoice;
}
public void setMailOrEmailInvoice(String mailOrEmailInvoice) {
    this.mailOrEmailInvoice = mailOrEmailInvoice;
}
public String getMonthlyBillOnDay() {
    return monthlyBillOnDay;
}
public void setMonthlyBillOnDay(String monthlyBillOnDay) {
    this.monthlyBillOnDay = monthlyBillOnDay;
}
public CreditCard getCreditCard() {
    return creditCard;
}
public void setCreditCard(CreditCard creditCard) {
    this.creditCard = creditCard;
}

 }
信用卡课程

   public class CreditCard {

private String type;
private String cardNumber;
private String name;
private String securityCode;
private String expirationDate;
private String firstFourDigit;
private String secondFourDigit;
private String thirdFourDigit;
private String lastFourDigits;
private String zipCode;



public void setMonth(String month){
    if(expirationDate==null)
        expirationDate=month;
    else
        expirationDate=month+"/"+expirationDate;
}

public void setYear(String year){
    if(expirationDate==null)
        expirationDate=year;
    else
        expirationDate=expirationDate+"/"+year;
}

public String getMonth() {
    return "";
}

public String getYear() {
    return "";
}

public String getType() {
    return type;
}

public void setType(String type) {
    this.type = type;
}

public String getCardNumber() {
    if (cardNumber == null)
        cardNumber = firstFourDigit + secondFourDigit + thirdFourDigit
                + lastFourDigits;
    return cardNumber;
}

public void setCardNumber(String cardNumber) {
    this.cardNumber = cardNumber;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public String getSecurityCode() {
    return securityCode;
}

public void setSecurityCode(String securityCode) {
    this.securityCode = securityCode;
}

public String getExpirationDate() {
    return expirationDate;
}

public void setExpirationDate(String expirationDate) {
    this.expirationDate = expirationDate;
}

public String getFirstFourDigit() {
    return firstFourDigit;
}

public String getSecondFourDigit() {
    return secondFourDigit;
}

public String getThirdFourDigit() {
    return thirdFourDigit;
}

public String getLastFourDigits() {
    return lastFourDigits;
}

public void setLastFourDigits(String lastFourDigits) {
    this.lastFourDigits = lastFourDigits;
}

public void setFirstFourDigit(String firstFourDigit) {
    this.firstFourDigit = firstFourDigit;
}

public void setSecondFourDigit(String secondFourDigit) {
    this.secondFourDigit = secondFourDigit;
}

public void setThirdFourDigit(String thirdFourDigit) {
    this.thirdFourDigit = thirdFourDigit;
}

public String getZipCode() {
    return zipCode;
}

public void setZipCode(String zipCode) {
    this.zipCode = zipCode;
}

  }
问题就在这里。因为在自省期间,spring会查找一个名为
setXXX
的字段,而不是
set

编辑(建议的解决方案):


请张贴付款类别代码。我添加了类别。只是我已经注意到信用卡的问题,如果我从payment类中删除类引用,那么一切都会正常运行,你有什么建议吗?那么如何解决这个问题,我可以给出任何注释,这样它就会忽略那些setter方法。或者可以指示使用setter方法进行bean填充。因为这些方法无法删除。我正在使用它们来正确显示数据。对我来说,这还不清楚,代码中没有注释,所以不应该浏览这个分支。(看起来像是框架中的一个bug)。我会修改(见编辑)以摆脱这种情况。在我将看到编辑的地方,我会以任何方式搜索解决方案。正如我在视图层中使用的自定义setter方法一样
   public class CreditCard {

private String type;
private String cardNumber;
private String name;
private String securityCode;
private String expirationDate;
private String firstFourDigit;
private String secondFourDigit;
private String thirdFourDigit;
private String lastFourDigits;
private String zipCode;



public void setMonth(String month){
    if(expirationDate==null)
        expirationDate=month;
    else
        expirationDate=month+"/"+expirationDate;
}

public void setYear(String year){
    if(expirationDate==null)
        expirationDate=year;
    else
        expirationDate=expirationDate+"/"+year;
}

public String getMonth() {
    return "";
}

public String getYear() {
    return "";
}

public String getType() {
    return type;
}

public void setType(String type) {
    this.type = type;
}

public String getCardNumber() {
    if (cardNumber == null)
        cardNumber = firstFourDigit + secondFourDigit + thirdFourDigit
                + lastFourDigits;
    return cardNumber;
}

public void setCardNumber(String cardNumber) {
    this.cardNumber = cardNumber;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public String getSecurityCode() {
    return securityCode;
}

public void setSecurityCode(String securityCode) {
    this.securityCode = securityCode;
}

public String getExpirationDate() {
    return expirationDate;
}

public void setExpirationDate(String expirationDate) {
    this.expirationDate = expirationDate;
}

public String getFirstFourDigit() {
    return firstFourDigit;
}

public String getSecondFourDigit() {
    return secondFourDigit;
}

public String getThirdFourDigit() {
    return thirdFourDigit;
}

public String getLastFourDigits() {
    return lastFourDigits;
}

public void setLastFourDigits(String lastFourDigits) {
    this.lastFourDigits = lastFourDigits;
}

public void setFirstFourDigit(String firstFourDigit) {
    this.firstFourDigit = firstFourDigit;
}

public void setSecondFourDigit(String secondFourDigit) {
    this.secondFourDigit = secondFourDigit;
}

public void setThirdFourDigit(String thirdFourDigit) {
    this.thirdFourDigit = thirdFourDigit;
}

public String getZipCode() {
    return zipCode;
}

public void setZipCode(String zipCode) {
    this.zipCode = zipCode;
}

  }
public void setMonth(String month){
    // ...
}

public void setYear(String year){
    // ...
}
public class CreditCard {
    public static class ExpirationDate {
        private String month;
        private String year;

        // getters, setter

        @Override
        public String toString() {
            return month + "/" + year;
        }
    }

    private String type;
    private String cardNumber;
    private String name;
    private String securityCode;
    private ExpirationDate expirationDate;
    private String firstFourDigit;
    private String secondFourDigit;
    private String thirdFourDigit;
    private String lastFourDigits;
    private String zipCode;

    public void setExpirationDate(ExpirationDate expDate){
        this.expirationDate = expDate;
    }

    public ExpirationDate getExpirationDate(){
        return this.expirationDate;
    }

    // other getters, setters
}