JSONArray 过滤

说明

将一个List ResponseBody到前端页面报错

原因

TProjectXXX实体里面存在OneToMany的属性

解决办法

使用SimplePropertyPreFilter过滤,只留下我需要的字段

/**
 * 第一种:在对象响应字段前加注解,这样生成的json也不包含该字段。
 */
 @JSONField(serialize=false)  
 private String name;  


/**
 * 第二种:在对象对应字段前面加transient,表示该字段不用序列化,即在生成json的时候就不会包含该字段了。
 */
  private transient  String name;  
 

/**
 * 第三种:使用fastjson的拦截器
 */
 PropertyFilter profilter = new PropertyFilter(){  
	   @Override  
	    public boolean apply(Object object, String name, Object value) {  
	        if(name.equalsIgnoreCase("last")){  
	            //false表示last字段将被排除在外  
	            return false;  
	        }  
	        return true;  
	    }  
};  
json = JSON.toJSONString(user, profilter);  
System.out.println(json);   

/**
 * 第四种,直接填写属性
 */
 SimplePropertyPreFilter filter = new SimplePropertyPreFilter(TTown.class, "id","townname");  
 response.getWriter().write(JSONObject.toJSONString(townList,filter));   

附加

  1. @Transient

@Transient表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性;
如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则ORM框架默认其注解为@Basic;

//表示该字段在数据库表中没有

@Transient
public int getAge() {
 return 1+1;
}

Jackson相关:

  1. @JsonIgnoreProperties

此注解是类注解,作用是json序列化时将java bean中的一些属性忽略掉,序列化和反序列化都受影响。

  1. @JsonIgnore

此注解用于属性或者方法上(最好是属性上),作用和上面的@JsonIgnoreProperties一样。

  1. @JsonFormat

此注解用于属性或者方法上(最好是属性上),可以方便的把Date类型直接转化为我们想要的模式,比如@JsonFormat(pattern = “yyyy-MM-dd HH-mm-ss”)

  1. @JsonSerialize

此注解用于属性或者getter方法上,用于在序列化时嵌入我们自定义的代码,比如序列化一个double时在其后面限制两位小数点。

  1. @JsonDeserialize

此注解用于属性或者setter方法上,用于在反序列化时可以嵌入我们自定义的代码,类似于上面的@JsonSerialize

你可能感兴趣的:(日常记录,工具类,ERR)