为实体类增加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 ...
随机推荐
- spring service层单元测试
service层测试较简单,目前大多数测试主要是针对public方法进行的.依据测试方法划分,可以分为两种:基于mock的隔离测试和基于dbunit的普通测试. mock隔离测试 配置pom.xml ...
- RFID智能感知摄像机推进智慧城市建设步伐
随着智慧城市建设步伐的大力推进,各地的智慧城市建设取得了卓有成效的成果.物联网工程正在如火如荼地进行,顺应智慧城市物联网的发展大趋势,建设城市级的视频感知网,涉及治安.交通.教育等多方面综合传感应用, ...
- javascript基础-表单
图解: 表单只需要知道常用的,其他的了解原理就行.在实际项目中,序列化一般用库(jquery)带的方法.富文本引用组件.
- Swoole笔记(三)
WebSocket 使用Swoole可以很简单的搭建异步非阻塞多进程的WebSocket服务器. WebSocket服务器 <?php $server = new swoole_websocke ...
- 【PHP】最详细PHP从入门到精通(二)——PHP中的函数
PHP从入门到精通 之PHP中的函数 各位开发者朋友大家好,自上次更新PHP的相关知识,得到了大家的广泛支持.PHP的火爆程度不言而喻,函数作为PHP中极为重要的部分,应诸位的支持,博主继续跟进更新 ...
- 在附件管理模块中增加对FTP 上传和预览的支持
在之前介绍的附件管理模块里面<Winform开发框架之通用附件管理模块>以及<Winform开发框架之附件管理应用>,介绍了附件的管理功能,通过对数据库记录的处理和文件的管理, ...
- 华为A199:近期不会再买华为的手机了
为了支持国货,也省点钱,买了个华为A199: 缺点: 没有google play market很复杂的刷机后才能装Gmail 不过也有亮点: 自带录音功能,老htc通过软件也只能录单方向的哦关机闹 ...
- PHP的面向对象 — 封装、继承、多态
K在上一次的基础篇中给大家介绍了一下关于PHP中数组和字符串的使用方法等,这一次,K决定一次性大放送,给大家分享一下PHP中面向对象的三大特性:封装.继承.多态三个方面的知识. 一.封装 在PHP中, ...
- Java NIO学习笔记一 Java NIO概述
Java NIO概述 Java NIO(新的IO)是Java的替代IO API(来自Java 1.4),这意味着替代标准的 java IO和java Networking API.Java NIO提供 ...
- JavaScript严格模式有什么不同
看ES6,瞄到“严格模式”,问了下自己什么是“严格模式”?答案好像不是很明朗,遂总结如下: 严格模式声明:“use strict”; 1.禁止变量未声明就赋值 2.限制动态绑定(属性和方法归属哪个对象 ...