使用Hibernate manytoone属性关联主表的时候,如果使用JSONArray把pojo对象转换成json对象时,很容易出现循环的异常。解决的办法就是,
在转换json对象时忽略manytoone属性的对象。比如student类中有course属性,忽略course属性,就不会再出错。
当pojo对象中存在时间(Date)类型时,转换成json后的对象,时间格式不符合使用要求。在转换时,可以定义时间的格式。
public String getJson(List<Student> list){ JsonConfig jsonConfig = new JsonConfig(); //建立配置文件 jsonConfig.setIgnoreDefaultExcludes(false); //设置默认忽略 jsonConfig.setExcludes(new String[]{"course"}); // 设置javabean中日期转换时的格式 jsonConfig.registerJsonValueProcessor(Date.class, new JsonDateValueProcessor("yyyy-MM-dd")); JSONArray json=JSONArray.fromObject(list,jsonConfig); return json; }
时间格式转换辅助类
package org.jeecgframework.web.ksxdcgzh.entity; import java.text.SimpleDateFormat; import java.util.Date; import net.sf.json.JsonConfig; import net.sf.json.processors.JsonValueProcessor; public class JsonDateValueProcessor implements JsonValueProcessor{ private String format = "yyyy-MM-dd HH:mm:ss"; public JsonDateValueProcessor() { } public JsonDateValueProcessor(String format) { this.format = format; } @Override public Object processArrayValue(Object value, JsonConfig jsonConfig) { // TODO Auto-generated method stub String[] obj = {}; if (value instanceof Date[]) { SimpleDateFormat sf = new SimpleDateFormat(format); Date[] dates = (Date[]) value; obj = new String[dates.length]; for (int i = 0; i < dates.length; i++) { obj[i] = sf.format(dates[i]); } } return obj; } @Override public Object processObjectValue(String key, Object value, JsonConfig jsonConfig) { // TODO Auto-generated method stub if (value instanceof Date) { String str = new SimpleDateFormat(format).format((Date) value); return str; } return value; } public String getFormat() { return format; } public void setFormat(String format) { this.format = format; } }
2
在一对多的实体关系中,转换json时要忽略引用的属性。
@Entity @Table(name = "studentl", schema = "") @DynamicUpdate(true) @DynamicInsert(true) @SuppressWarnings("serial") @JsonIgnoreProperties(value={"course"}) //转换json时忽略course对象,以免造成死循环 public class StudentEntity implements java.io.Serializable { private courseEntity course; ...... }