spring.HttpMessageNotReadableException: JSON parse error

实体类如下:

java 复制代码
@Value
public class Search{
    //搜索内容
	String value;
	//是否模糊搜索
	boolean fuzzy = true; //其实这样写并不是"默认"模糊搜索,而是"一定是"模糊搜索
}

spring.HttpMessageNotReadableException: JSON parse error: Cannot construct instance of com.erato.xxx.Student (although at least one Creator exists): cannot deserialize from Object value (no-delegate- or property based Creater); nested exception is com.fastetxml.jackson.databind.exc.MismatchedInputException: ...

去网上一搜,全都在说没有是因为没有空参构造器 NoArgsConstructor。实际上这只是表面。 有时候即使没有空参构造器也无所谓。

上面情况的问题在于,@value 会给两个成员变量 member field 都加上 final.

首先明确一下 java 基础知识点:如果 class 里只有两个 final 的成员变量 member field. 那 空参 和 全参 两个构造器是没法共存的。

空参会警告告诉你给 member field 赋初值(其实不能叫初值,该叫'永久值'),

java 复制代码
@Value
@NoArgsConstructor
public class Search{
	String value; //报错,Variable 'value' might not have been initialized
	boolean fuzzy = true;
}

全参 会警告告诉你不要给 member field 赋初值。

java 复制代码
@Value
@AllArgsConstructor
public class Search{
	String value = ""; 
	boolean fuzzy = true;
	public Student(String value, boolean fuzzy){
		this.value = value;//报错 cannnot assign a value to final variable 'value'
		this.fuzzy = fuzzy;
	}
}

情况1

我们来看看让实体类有 no args constructor.

实体类如下:

java 复制代码
@Value
@NoArgsConstructor
public class Search{
	String value = "";
	boolean fuzzy = true;
}

为了编译 compile 不爆红我们只好这样。

其实这样写等于白写了,连搜索内容都是写死的你想想,啥功能都没实现。不管你前端传啥,后端的实例 instance 都永远是是 Student (value=, fuzzy=true). 我们就只先做实验,非得这么写。会发生什么呢?

前端传参:

json 复制代码
{
	"value":"abc",
	"fuzzy":true
}

能通过,但没什么用。

情况2

java 复制代码
@Value
Student {
	String value;
	boolean fuzzy;
	public Student(String value, boolean fuzzy) {
		this.value = value;
		this.fuzzy = fuzzy;
	}
}

前端:

json 复制代码
{
	"value":"abc",
	"fuzzy":true
}

此时并没有空参构造器,但并没有报这个错。可见那些抄来抄去的文章是多么的没价值。

情况3

@AllArgsConstructor 是非常智能的。事实上它并不是"全参构造器"的意思!! 假设一个赋值了一个没赋值:

java 复制代码
@Value
@AllArgsConstructor
Student {
	String value;
	boolean fuzzy = true;
	public Student(String value, boolean fuzzy) {
		this.value = value;
		this.fuzzy = fuzzy;
	}
}

ctrl+F12 我们会看到只添了一个构造方法 , **Student(String value).

**

你前端不管传几个都会报错:

spring.HttpMessageNotReadableException: JSON parse error: Cannot construct ...

相关推荐
后端小张8 小时前
【JAVA进阶】Spring Boot 核心知识点之自动配置:原理与实战
java·开发语言·spring boot·后端·spring·spring cloud·自动配置
阿巴~阿巴~13 小时前
JsonCpp:C++ JSON处理利器
linux·网络·c++·json·tcp·序列化和反序列化
8***848214 小时前
spring security 超详细使用教程(接入springboot、前后端分离)
java·spring boot·spring
boonya14 小时前
Java中Plugin设计模式的规范应用
java·spring·设计模式·插件模式
o***592715 小时前
Spring 过滤器:OncePerRequestFilter 应用详解
java·后端·spring
m***l11516 小时前
SpringMVC的工作流程
状态模式
曹牧16 小时前
Java: Json的键值双引号
java·chrome·json
有一个好名字16 小时前
Spring AI ——Java开发者的AI集成神器
java·人工智能·spring
最笨的羊羊17 小时前
Flink CDC系列之:Kafka JSON 序列化器JsonSerializationSchema
json·schema·flink cdc·serialization·序列化器·系列·kafkajson
e***956417 小时前
springboot-自定义注解
java·spring boot·spring