为实体类增加toJSON方法
后期子类继承该基础类即可。
package com.lichmama.test;
import java.io.Serializable;
import java.lang.reflect.Field;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
public class BaseEntity implements Serializable {
/**
*
*/
private static final long serialVersionUID = -5311594725961174392L;
/**
* modifier for "private static final"
*/
private static final int privateStaticFinal = 26;
@Override
public String toString() {
try {
return toJSON();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
return null;
}
public String toJSON() throws IllegalArgumentException, IllegalAccessException {
StringBuilder jsonBuff = new StringBuilder();
jsonBuff.append("{");
Field[] fields = this.getClass().getDeclaredFields();
for (Field item : fields) {
if (item.getModifiers() == privateStaticFinal) {
continue;
}
item.setAccessible(true);
String name = item.getName();
jsonBuff.append("\"" + name + "\"" + ":");
Object value = item.get(this);
if (value != null) {
Class<?> type = item.getType();
if (type == String.class) {
jsonBuff.append(value);
} else if (type == int.class || type == Integer.class) {
jsonBuff.append(value);
} else if (type == short.class || type == Short.class) {
jsonBuff.append(value);
} else if (type == long.class || type == Long.class) {
jsonBuff.append(value);
} else if (type == float.class || type == Float.class) {
jsonBuff.append(value);
} else if (type == double.class || type == Double.class) {
jsonBuff.append(value);
} else if (type == char.class || type == Character.class) {
jsonBuff.append("\"" + value + "\"");
} else if (type == boolean.class || type == Boolean.class) {
jsonBuff.append(value);
} else if (type == Map.class) {
jsonBuff.append(mapToString((Map)value));
} else if (type == List.class) {
jsonBuff.append(listToString((List)value));
} else if (type.getSuperclass() == BaseEntity.class) {
jsonBuff.append(((BaseEntity)value).toJSON());
}
}
jsonBuff.append(",");
}
return rtrim(jsonBuff, ",") + "}";
}
public String mapToString(Map<String, ? extends Object> map) {
StringBuilder buff = new StringBuilder();
Iterator<String> iter = map.keySet().iterator();
buff.append("{");
while (iter.hasNext()) {
String name = iter.next();
Object value = map.get(name);
buff.append("\"" + name + "\"" + ":");
if (value != null) {
String valueStr = String.valueOf(value);
if (value.getClass() == String.class) {
buff.append("\"" + valueStr + "\"");
} else {
buff.append(valueStr);
}
}
buff.append(",");
}
return rtrim(buff, ",") + "}";
}
public String listToString(List<? extends Object> list) {
StringBuilder buff = new StringBuilder();
buff.append("[");
for (Object value : list) {
String valueStr = String.valueOf(value);
if (value.getClass() == String.class) {
buff.append("\"" + valueStr + "\"");
} else {
buff.append(valueStr);
}
buff.append(",");
}
return rtrim(buff, ",") + "]";
}
public String rtrim(StringBuilder buff, String suffix) {
String content = buff.toString();
if (content.endsWith(suffix)) {
content = content.substring(0, content.length() - suffix.length());
}
return content;
}
}
测试下:
class User extends BaseEntity {
private String username;
private String password;
// 此处省略掉getter/setter方法
}
class Department extends BaseEntity {
private int id;
private User chief;
private String deptName;
// 此处省略掉getter/setter方法
}
public class TestCase {
public static void main(String[] args) {
User chief = new User();
chief.setUsername("lichmama");
chief.setPassword("12345678");
Department dept = new Department();
dept.setChief(chief);
dept.setId(101);
dept.setDeptName("R&D");
System.out.println(dept.toString());
}
}
{
"id": 101,
"chief": {
"username": "lichmama",
"password": "12345678"
},
"deptName": "R&D"
}
that's it.
为实体类增加toJSON方法的更多相关文章
- hql语句查询实体类采用list方法的返回结果集
在hibernate中,用hql语句查询实体类,采用list方法的返回结果为一个List,该List中封装的对象分为以下三种情况:1.查询全部字段的情况下,如"from 实体类", ...
- SPRING IN ACTION 第4版笔记-第四章ASPECT-ORIENTED SPRING-010-Introduction为类增加新方法@DeclareParents、<aop:declare-parents>
一. 1.Introduction的作用是给类动态的增加方法 When Spring discovers a bean annotated with @Aspect , it will automat ...
- Spring JdbcTemplate的queryForList(String sql , Class<T> elementType)返回非映射实体类的解决方法
Spring JdbcTemplate的queryForList(String sql , Class<T> elementType)易错使用 一直用ORM,今天用JdbcTemplate ...
- 【技术】JavaSE环境下JPA实体类自动注册
在没有容器支持的环境下,JPA的实体类(Entity)一般要在persistence.xml中逐个注册,类似下面这样: <?xml version="1.0" encodin ...
- Mybaits 源码解析 (八)----- 全网最详细,没有之一:结果集 ResultSet 自动映射成实体类对象(上篇)
上一篇文章我们已经将SQL发送到了数据库,并返回了ResultSet,接下来就是将结果集 ResultSet 自动映射成实体类对象.这样使用者就无需再手动操作结果集,并将数据填充到实体类对象中.这可大 ...
- 实体类(VO,DO,DTO,PO)的划分《转载---》
转载自:https://blog.csdn.net/u010722643/article/details/61201899 经常会接触到VO,DO,DTO的概念,本文从领域建模中的实体划分和项目中的实 ...
- java 项目中几种O实体类的概念
经常会接触到vo,do,dto的概念,本文从领域建模中的实体划分和项目中的实际应用情况两个角度,对这几个概念进行简析. 得出的主要结论是:在项目应用中,vo对应于页面上需要显示的数据(表单),do对应 ...
- [转]实体类(VO,DO,DTO)的划分
原文地址:http://blog.sina.com.cn/s/blog_7a4cdec80100wkyh.html 经常会接触到VO,DO,DTO的概念,本文从领域建模中的实体划分和项目中的实际应用情 ...
- 领域模型中的实体类分为四种类型:VO、DTO、DO、PO
http://kb.cnblogs.com/page/522348/ 由于不同的项目和开发人员有不同的命名习惯,这里我首先对上述的概念进行一个简单描述,名字只是个标识,我们重点关注其概念: 概念: V ...
随机推荐
- 谷歌发布基于机器学习的Android APP安全检测系统:Google Play Protect
Google Play作为众所周知的在线应用市场,因为审查制度的松散,经常会有一些恶意软件伪装成其他应用混入其中.此前阿里聚安全小编就报道了2例关于恶意软件伪装在Google Play上的事件:< ...
- 关于EF中直接执行sql语句的参数化问题
某天 , 在review项目中代码的时候, 发现有哥们直接通过 Database.ExecuteSqlCommand("select * from order_info where com ...
- c语言项目开发流程二部曲
一.在第一部曲中我们介绍了电子词典项目开发的前5步,下面继续我们的步伐. 6.函数接口设计,这一步不是一蹴而就的,在项目进行中得不断修改,下面是我电子词典项目接口. /**************函数 ...
- CodeForces 544C (Writing Code)(dp,完全背包)
题意:有n个程序员,要协作写完m行代码,最多出现b个bug,第i个程序员每写一行代码就会产生a[i]个bug,现在问,这n个人合作来写完这m行代码,有几种方案使得出的bug总数不超过b(题中要求总方案 ...
- nodeJs中npm详解
npm 是 Node.js 的模块依赖管理工具.作为开发者使用的工具,主要解决开发 node.js 时会遇到的问题.如同 RubyGems 对于 Ruby 开发者和 Maven 对于 Java 开发者 ...
- Docker-compose实战——Django+PostgreSQL
今天我们来用docker-compose 快速安装一个Django+PostgreSQL的开发环境. Compose简介 Compose 定位是“defining and running comple ...
- javaCV图像处理之Frame、Mat和IplImage三者相互转换(使用openCV进行Mat和IplImage转换)
前言:本篇文章依赖四个jar包,其中javacv.jar,javacpp.jar和opencv.jar为固定jar包,opencv-系统环境.jar为选配(根据自己的系统平台,x64还是x86而定) ...
- 【毕业设计】基于Android的家校互动平台开发(内含完整代码和所有文档)——爱吖校推(你关注的,我们才推)
☆ 写在前面 之前答应大家的毕业答辩之后把所有文档贡献出来,现在答辩已过,LZ信守承诺,把所有文档开源到了GitHub(这个地址包含所有的代码和文档以及PPT,外层为简单的代码).还望喜欢的朋友们,不 ...
- Nmap在实战中的高级用法
Nmap提供了四项基本功能(主机发现.端口扫描.服务与版本侦测.OS侦测)及丰富的脚本库.Nmap既能应用于简单的网络信息扫描,也能用在高级.复杂.特定的环境中:例如扫描互联网上大量的主机:绕开防火墙 ...
- A comparison of local caches (2) 【本地缓存之比较 (2)】
接上一篇: A comparison of local caches (1) [本地缓存之比较 (1)] This article will compare the asynchronous loca ...