通常定义Java实体类时,对于boolean属性,阿里规约中明确要求不能使用is开头。
至于为什么,我们稍后再讲。
这里先讲一下前几天在工作中,项目遇到的一个问题。库表中某个字段存入了一个实体类的json字符串,在查询库表后,需要将json字符串转为实体类对象进行更改后再转为json字符串后返回给前端。
在这当中就出现了一个问题,库表中存入的数据明明是isUpdate的字段,可是在返回到前端后的代码就是update。
这个问题,起初并没有想到是字段定义的问题,通过一步一步的debug,最后才发现是实体类中isUpdate字段的问题,在通过json解析后就转成了update返回给了前端。
下面讲一下,为什么会出现isUpdate变成update的问题。
首先,我们先定义一个Java实体类,包含一个is开头的属性,如isSuccess,再使用idea自动生成的get/set,看看是什么样子。
typescript
代码解读
复制代码
public class IsEntity1 {
private boolean isSuccess;
public boolean isSuccess() {
return isSuccess;
}
public void setSuccess(boolean success) {
isSuccess = success;
}
}
然后再定义一个Java实体类,不是用is开头的属性,如success,再使用idea自动生成的get/set,看看是什么样子。
typescript
代码解读
复制代码
public class IsEntity2 {
private boolean success;
public boolean isSuccess() {
return success;
}
public void setSuccess(boolean success) {
this.success = success;
}
}
此时,会发现无论你是用is开头或者不用is开头定义属性,使用idea自动生成的get/set都是一个样子的,而且在setSuccess的时候,会将is省略掉。这里就是项目中遇到的问题所在。
因为当类进行序列化时,有些框架的序列化会根据JavaBean的属性进行序列化,而部分框架是根据JavaBean的getter方法进行序列化,这就会导致在反序列化时与实体类的属性对应不上。
比如说将IsEntity1转换为json字符串时,会根据实体类中的get方法进行序列化取isSuccess的值,而使用idea自动生成的get方法直接就是public boolean isSuccess()方法,在取值的时候会认定success是字段名,就会取成success,与原来定义的字段不同。
如果非要使用is开头来定义字段,怎么才能保证json解析过程是正确的呢
答案是自己写get方法,不用idea自动生成的get方法。
如下:
typescript
代码解读
复制代码
public boolean getIsSuccess() {
return isSuccess;
}
这样,再将实体类转为json字符串时,就会认定isSuccess是字段名。
还有一种方法,就是使用JSONField注解
ini
代码解读
复制代码
@JSONField(name = "isSuccess")
private boolean isSuccess;
虽然这些方法都可以解决json解析过程丢失is的问题,但是为了避免出现这种问题,我们最好还是遵守规约,不使用is开头定义字段。