关于如何处理JSONObject.fromObject(Object obj)无法转换特殊日期(java.sql.Date,java.sql.Timestamp)格式的问题。
转:关于如何处理JSONObject.fromObject(Object obj)无法转换特殊日期(java.sql.Date,java.sql.Timestamp)格式的问题。
关于JSONObject的封装,或者说使用,现在市面上很多。这里不做过多的描述,但是有种情况却不得不说明下,JSONObject进行对对象进行JSON格式转换,但是在转换过程中,遇到了
Java.sql.Date类型的属性无法完成转换,并且抛出异常:net.sf.json.JSONException:
java.lang.reflect.InvocationTargetException
很多人遇到这个问题后,应该会查询百度等搜索引擎,那么可能得到一种类型转换的说法,我们也得到这样的说法,
后来多方测试,也确实是这个问题。如何解决?
或许很多人会说,那既然时间格式无法转换,我们可以转换设计类型嘛,数据库中我们不用date或datetime,直接用
varchar,而java中直接用String好了。确实这不失一个解决问题的办法,但是如果我们不改呢?
下面是我给出的设计图:
在这个设计图中,我给出了一个接口JsonValueProcessor ,这个接口可以自定义一些JSON类型转换器,正好,我就
分别定义了3种不同类型的类型转换器。
分析上图,我定义了3种角色:
1、类型转换器抽象接口:分别定义了2个接口方法,一个用于处理数组,一个用于处理属性类型;
2、类型转换器具体实现类:实现了上述抽象接口类的接口方法;
3、调用者:用户通过调用“调用者”的方法,完成由对象向JSONObject转换。
类型转换器抽象接口,由json-lib.jar提供,我们不必定义。
处理java.sql.Date类型属性的类型转换器:
- package com.lovo.util;
- import java.text.SimpleDateFormat;
- import java.util.Date;
- import net.sf.json.JsonConfig;
- import net.sf.json.processors.JsonValueProcessor;
- /**
- * 定义一个自己的时间适配处理器
- * @author Administrator
- *
- */
- public class SQLDateProcessor implements JsonValueProcessor{
- private String format = "yyyy-MM-dd hh:mm:ss";//自定义时间格式化的样式
- public SQLDateProcessor() {
- super();
- // TODO Auto-generated constructor stub
- }
- public SQLDateProcessor(String format) {
- this.format = format;
- }
- public Object processArrayValue(Object arg0, JsonConfig arg1) {
- // TODO Auto-generated method stub
- return arg0;
- }
- /**
- * 处理对象的值
- * str 这个参数是当前需要处理的属性名
- */
- public Object processObjectValue(String str, Object obj, JsonConfig arg2) {
- // TODO Auto-generated method stub
- String ret = "";
- if(obj instanceof java.sql.Date){
- SimpleDateFormat sdf = new SimpleDateFormat(format);
- ret = sdf.format(new Date(((java.sql.Date) obj).getTime()));
- }
- return ret;
- }
- }
处理java.util.Date类型的类型转换器:
- package com.lovo.util;
- import java.text.SimpleDateFormat;
- import java.util.Date;
- import net.sf.json.JsonConfig;
- import net.sf.json.processors.JsonValueProcessor;
- /**
- * 定义一个自己的时间适配处理器
- * @author Administrator
- *
- */
- public class UtilDateProcessor implements JsonValueProcessor{
- private String format = "yyyy-MM-dd hh:mm:ss";//自定义时间格式化的样式
- public UtilDateProcessor() {
- super();
- // TODO Auto-generated constructor stub
- }
- public UtilDateProcessor(String format) {
- this.format = format;
- }
- public Object processArrayValue(Object arg0, JsonConfig arg1) {
- // TODO Auto-generated method stub
- return arg0;
- }
- /**
- * 处理对象的值
- * str 这个参数是当前需要处理的属性名
- */
- public Object processObjectValue(String str, Object obj, JsonConfig arg2) {
- // TODO Auto-generated method stub
- String ret = "";
- if(obj instanceof java.util.Date){
- SimpleDateFormat sdf = new SimpleDateFormat(format);
- ret = sdf.format(((Date) obj).getTime());
- }
- return ret;
- }
- }
处理java.sql.Timestamp类型的类型转换器:
- package com.lovo.util;
- import java.text.SimpleDateFormat;
- import java.util.Date;
- import net.sf.json.JsonConfig;
- import net.sf.json.processors.JsonValueProcessor;
- /**
- * 定义一个自己的时间适配处理器
- * @author Administrator
- *
- */
- public class TimestampProcessor implements JsonValueProcessor{
- private String format = "yyyy-MM-dd hh:mm:ss";//自定义时间格式化的样式
- public TimestampProcessor() {
- super();
- // TODO Auto-generated constructor stub
- }
- public TimestampProcessor(String format) {
- this.format = format;
- }
- public Object processArrayValue(Object arg0, JsonConfig arg1) {
- // TODO Auto-generated method stub
- return arg0;
- }
- /**
- * 处理对象的值
- * str 这个参数是当前需要处理的属性名
- */
- public Object processObjectValue(String str, Object obj, JsonConfig arg2) {
- // TODO Auto-generated method stub
- String ret = "";
- if(obj instanceof java.sql.Timestamp){
- SimpleDateFormat sdf = new SimpleDateFormat(format);
- ret = sdf.format(((Date) obj).getTime());
- }
- return ret;
- }
- }
调用者类:
- package com.lovo.util;
- import java.util.Iterator;
- import java.util.Map;
- import net.sf.json.JSONObject;
- import net.sf.json.JsonConfig;
- import net.sf.json.processors.JsonValueProcessor;
- /**
- * JSON格式转换类
- * @author Administrator
- *
- */
- public class JSONUtil {
- /**
- * 将一个对象直接转换为一个JSONObject对象,
- * 同样适合于JSON格式的字符串
- * 但是如果存在java.sql.Date或者java.sql.Timestamp时间格式,调用例外一个toJson转换方法
- * @param obj
- * @return
- */
- public static JSONObject toJson(Object obj) {
- return JSONObject.fromObject(obj);
- }
- /**
- *
- * @param obj 需要转换的参数
- * @param processors 类型转换器的集合,参数是一个Map集合,键代表需要转换类型的全路径,值是类型转换器
- * @return
- * @throws ClassNotFoundException
- */
- public static JSONObject toJson(Object obj,Map<String,JsonValueProcessor> processors) throws ClassNotFoundException{
- //定义一个JSONConfig对象,该对象可以制定一个转换规则
- JsonConfig config = new JsonConfig();
- if(processors != null && !processors.isEmpty()){
- Iterator<java.util.Map.Entry<String, JsonValueProcessor>> it = processors.entrySet().iterator();
- while (it.hasNext()) {
- Map.Entry<java.lang.String, net.sf.json.processors.JsonValueProcessor> entry = (Map.Entry<java.lang.String, net.sf.json.processors.JsonValueProcessor>) it
- .next();
- String key = entry.getKey();
- JsonValueProcessor processor = processors.get(key);
- //反射获取到需要转换的类型
- Class<?> cls = Class.forName(key);
- config.registerJsonValueProcessor(cls, processor);
- }
- }
- return JSONObject.fromObject(obj, config);
- }
- }
客户端调用“调用者”类,来完成对象向JSONObject进行转换:
- package com.test.util;
- import java.sql.Date;
- import java.sql.Timestamp;
- import java.util.HashMap;
- import java.util.Map;
- import org.junit.Ignore;
- import org.junit.Test;
- import com.lovo.util.SQLDateProcessor;
- import com.lovo.util.JSONUtil;
- import com.lovo.util.TimestampProcessor;
- import com.lovo.util.User;
- import net.sf.json.JSONObject;
- import net.sf.json.processors.JsonValueProcessor;
- public class JSONTest {
- @Test
- public void testJsonObjectOne() {
- String shortFormat = "yyyy-MM-dd";
- String longFormat = "yyyy-MM-dd hh:mm:ss";
- Date sqlDate = new Date(System.currentTimeMillis());
- Timestamp createTime = new Timestamp(System.currentTimeMillis());
- User user = new User("高高", sqlDate, createTime);
- // 定义一个类型转化器集合,键是需要转换的类型全路径,值是用于转换的类型转换器
- Map<String, JsonValueProcessor> processors = new HashMap<String, JsonValueProcessor>();
- //有了2-3种时间转换器,那么我们设计时,就可以短时间格式用Date,长时间格式就是用Timestamp
- processors.put("java.sql.Date", new SQLDateProcessor(shortFormat));
- // processors.put("java.util.Date", new UtilDateProcessor(shortFormat));
- processors.put("java.sql.Timestamp", new TimestampProcessor(longFormat));
- JSONObject json = null;
- try {
- json = JSONUtil.toJson(user, processors);
- } catch (ClassNotFoundException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- System.out.println(json.toString());
- }
- /**
- * 将一个JSON格式的字符串转换为JSONObject对象,并获得其值
- */
- @Ignore
- public void testJsonObjectTwo() {
- // {"createTime":"2016-06-03 04:05:23","birthday":"2016-06-03","name":"高高"}
- String str = "{'createTime':'2016-06-03 04:05:23','birthday':'2016-06-03','name':'1'}";
- JSONObject json = null;
- try {
- json = JSONUtil.toJson(str, null);
- } catch (ClassNotFoundException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- System.out.println(json.get("name"));
- System.out.println(json.get("createTime"));
- System.out.println(json.get("birthday"));
- }
- }
得到的结果是:
- {"createTime":"2016-06-03 05:09:49","birthday":"2016-06-03","name":"高高"}
在JSONUtil类中,由于我们可以采用JSONConfig类来一次性注册多个类型转换器,所以我将多个类型转换器装配到
Map中,迭代Map集合采用反射机制来获取到需要转换的类型,向JSONConfig类中注册。
在这个过程中,封装了日期格式的传递,方便大家得到自己想要的日期格式。
关于如何处理JSONObject.fromObject(Object obj)无法转换特殊日期(java.sql.Date,java.sql.Timestamp)格式的问题。的更多相关文章
- java util.Date和sql.Date转换(时区转换)
public static Timestamp zoneTtime(String time) throws Exception{ time= "2018-08-01T10:01:21.905 ...
- JSONObject.fromObject(map)(JSON与JAVA数据的转换)
JSON与JAVA数据的转换(JSON 即 JavaScript Object Natation,它是一种轻量级的数据交换格式,非常适合于服务器与 JavaScript 的交互.) 上一篇文章中有这么 ...
- 转载:JSONObject.fromObject(map)(JSON与JAVA数据的转换)
转载网址:http://blog.sina.com.cn/s/blog_821025b70100wh6v.html JSON与JAVA数据的转换(JSON 即 JavaScript Object Na ...
- net.sf.json.JSONOBJECT.fromObject 与 com.alibaba.fastjson.JSONObject.parseObject
文章待补充,先写写以下知识点好了. NULL值处理之 net.sf.json.JSONObject 和 com.alibaba.fastjson.JSONObject区别 JSON作为一个轻量级的文本 ...
- java中object数据怎么转换成json数据
可以通过这个(json-lib-2.3-jdk15.jar)jar里的方法转换 JSONObject json = JSONObject.fromObject(Object); 如果对象数组 JSON ...
- 使用JSONObject.fromObject的时候出现“There is a cycle in the hierarchy”异常 的解决办法
在使用JSONObject.fromObject的时候,出现“There is a cycle in the hierarchy”异常. 意思是出现了死循环,也就是Model之间有循环包含关系: ...
- 解决JSONObject.fromObject数字为null时被转换为0
在使用JSONObject.fromObject的时候会遇到一种情况就是当对象的某一个Double型或Integer型的属性为空的时候,转JSON的时候会变成0.当一个布尔型的属性为空的时候,转JSO ...
- JSONObject.fromObject--JSON与对象的转换
1. List集合转换成json代码 List list = new ArrayList(); list.add( "first" ); list.add( "secon ...
- JSONObject处理java.util.Date
JSONObject的内容为: {"userId":"A000004FFDCE14","userName":"好好干g" ...
随机推荐
- 20160924-2——mysql常见问题集锦
一.数据类型相关问题 1.varchar(N)占用多少空间 (1)varchar(N)里的N是字符数,而不是字节数: (2)字符类型(varchar text blob等)空间=字符实际长度+字段长度 ...
- 任务05—学习 MARKDOWN 语言
我的简历地址: https://github.com/jinxiaohang/MyResume/blob/master/ForJavaJob.md 本任务主要目的掌握markdown. 1.首先是工具 ...
- Python中何时使用断言(转)
原文:http://blog.jobbole.com/76285/ 本文由 伯乐在线 - 贱圣OMG 翻译.未经许可,禁止转载!英文出处:python maillist.欢迎加入翻译小组. 这个问题是 ...
- 六百字读懂 Git(转)
add by zhj:还是原文 六百字读懂 Git 看着更舒服一些,显示更好 原文:六百字读懂 Git 英文原文:Git in 600 words 译注:来自 Hacker School 的 Mary ...
- Python3.6全栈开发实例[002]
2.判断用户传入的对象(字符串.列表.元组)长度是否大于5. li = [11,22,33,44,55,66,77,88,99,000,111,222] def func2(lst): if len( ...
- 转载:http://blog.csdn.net/foruok/article/details/53500801
凭兴趣求职80%会失败,为什么 标签: 求职跳槽找工作兴趣技术 2016-12-07 06:51 43316人阅读 评论(69) 收藏 举报 本文章已收录于: 分类: 随笔(144) 作者同类文章 ...
- vue_router打包(webpack)
把组件按组分块 有时候我们想把某个路由下的所有组件都打包在同个异步 chunk 中.只需要 给 chunk 命名,提供 require.ensure第三个参数作为 chunk 的名称: require ...
- Python的模块与函数以及与自动化的结合
3 模块与函数 3.1程序结构 python的程序由package,module,function组成,分别是包,模块,函数.模块是函数和类的集合,包,模块,函数之间的关系如下: 3.2模块 pyth ...
- sql server2005版本中,len函数计算了字符串末尾的空格
sql server2005版本中,len函数计算了字符串末尾的空格的长度,以下是测试脚本: print @@version declare @v varchar(max) set @v = 'hp, ...
- Python3 进程 线程 同步锁 线程死锁和递归锁
进程是最小的资源单位,线程是最小的执行单位 一.进程 进程:就是一个程序在一个数据集上的一次动态执行过程. 进程由三部分组成: 1.程序:我们编写的程序用来描述进程要完成哪些功能以及如何完成 2.数据 ...