spring post jackson的反序列化需要无参构造函数

2019-09-26 19:03:33

引言

在测试spring boot 的post传递实体类的过程中发现了一个反向序列化的异常。


异常

JSON parse error: Cannot construct instance of `com.**` (although at least one Creator exists): cannot deserialize from Object value (no delegate- or property-based Creator); nested exception is com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot construct instance of `com.**` (although at least one Creator exists): cannot deserialize from Object value (no delegate- or property-based Creator)

 at [Source: (PushbackInputStream); line: 2, column: 2]]

 


解决方案

在实体类中添加无参构造函数。


 


原因

jackson的反序列化需要无参构造函数,而我在实体类中添加了有参数的构造函数。


在实体类中添加无参构造函数即可。


 


修改前

 

import com.baomidou.mybatisplus.annotation.TableField;

import com.baomidou.mybatisplus.annotation.TableId;

import com.baomidou.mybatisplus.annotation.TableName;

import lombok.Data;

 

import java.io.Serializable;

 

@Data

@TableName("user")

public class User implements Serializable {

 

    @TableId("id")

    private String id;

    @TableField("user_id")

    private String userId;

    @TableField("device_id")

    private String deviceId;

 

    public User(String deviceId) {

        this.deviceId= deviceId;

    }

}

修改后

 

import com.baomidou.mybatisplus.annotation.TableField;

import com.baomidou.mybatisplus.annotation.TableId;

import com.baomidou.mybatisplus.annotation.TableName;

import lombok.Data;

 

import java.io.Serializable;

 

@Data

@TableName("user")

public class User implements Serializable {

 

    @TableId("id")

    private String id;

    @TableField("user_id")

    private String userId;

    @TableField("device_id")

    private String deviceId;

 

    public User() {

        super();

    }

 

    public User(String deviceId) {

        this.deviceId= deviceId;

    }

}

 



  • 2018-03-09 11:45:11

    SQL SELECT DISTINCT 语句

    如需从 Company" 列中仅选取唯一不同的值,我们需要使用 SELECT DISTINCT 语句:

  • 2018-03-13 22:42:44

    TraceView报错:unable to open trace file

    程序效率有些问题,想起用TraceView来分析一下,可是一直报标题中的错误,无法创建出我所需要的aa.trace文件,分析也就无从做起。

  • 2018-03-14 17:41:44

    MySQL的if,case语句使用总结

    Mysql的if既可以作为表达式用,也可在存储过程中作为流程控制语句使用,如下是做为表达式使用:

  • 2018-03-16 23:56:14

    layer-list -- layer-list的基本使用介绍

    简单理解,layer 是层,list 是列表,那么 layer-list 就是层列表的意思。但是,是什么层列表呢?? 其实 layer-list 是用来创建 LayerDrawable 的,LayerDrawable 是 DrawableResource 的一种, 所以,layer-list 创建出来的是 图层列表,也就是一个drawable 图形。