关于如何处理JSONObject.fromObject(Object obj)无法转换特殊日期(java.sql.Date,java.sql.Timestamp)格式的问题。

当使用JSONObject从对象转换时,遇到java.sql.Date和Timestamp类型转换失败的问题,可以自定义JSONValueProcessor接口实现转换。本文提供了解决方案,包括SQLDateProcessor、UtilDateProcessor和TimestampProcessor三个处理器,将日期转换为字符串格式。
摘要由CSDN通过智能技术生成

关于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类型属性的类型转换器:

[java]  view plain   copy
  在CODE上查看代码片 派生到我的代码片
  1. package com.lovo.util;  
  2.   
  3. import java.text.SimpleDateFormat;  
  4. import java.util.Date;  
  5.   
  6. import net.sf.json.JsonConfig;  
  7. import net.sf.json.processors.JsonValueProcessor;  
  8.   
  9. /** 
  10.  * 定义一个自己的时间适配处理器 
  11.  * @author Administrator 
  12.  * 
  13.  */  
  14. public class SQLDateProcessor implements JsonValueProcessor{  
  15.   
  16.     private String format = "yyyy-MM-dd hh:mm:ss";//自定义时间格式化的样式  
  17.     public SQLDateProcessor() {  
  18.         super();  
  19.         // TODO Auto-generated constructor stub  
  20.     }  
  21.       
  22.     public SQLDateProcessor(String format) {  
  23.         this.format = format;  
  24.     }  
  25.   
  26.     public Object processArrayValue(Object arg0, JsonConfig arg1) {  
  27.         // TODO Auto-generated method stub  
  28.         return arg0;  
  29.     }  
  30.     /** 
  31.      * 处理对象的值 
  32.      * str 这个参数是当前需要处理的属性名 
  33.      */  
  34.     public Object processObjectValue(String str, Object obj, JsonConfig arg2) {  
  35.         // TODO Auto-generated method stub  
  36.         String ret = "";  
  37.         if(obj instanceof java.sql.Date){  
  38.             SimpleDateFormat sdf = new SimpleDateFormat(format);  
  39.             ret = sdf.format(new Date(((java.sql.Date) obj).getTime()));  
  40.         }  
  41.         return ret;  
  42.     }  
  43.   
  44. }  



处理java.util.Date类型的类型转换器:

在使用JSONObject.fromObject()方法进行转换时,日期处理取决于你是否自定义了JsonDateValueProcessor类。如果你自定义了该类,并在其中重写了processObjectValue()方法,你可以通过在该方法中对日期进行格式化来处理日期。比如,你可以使用SimpleDateFormat类将日期格式化为指定的格式,如"yyyy-MM-dd"。然后在processObjectValue()方法中,将日期对象转换格式化后的字符串。 如果你没有自定义JsonDateValueProcessor类,那么JSONObject.fromObject()方法将默认将日期对象转换为long类型的时间戳。 所以,如果你希望在转换时对日期进行指定格式处理,你可以使用自定义的JsonDateValueProcessor类,并在其中实现你想要的日期格式化逻辑。这样,在调用JSONObject.fromObject()方法时,将会使用你自定义的日期处理逻辑对日期进行转换。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [JSONObject.fromObject 日期类型转换问题](https://blog.csdn.net/weixin_38158701/article/details/88057077)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [java jsonto对象互](https://download.csdn.net/download/a_158/8761205)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值