WEB层采用Spring MVC框架,将查询到的数据传递给APP端或客户端,这没啥,但是坑的是实体类中有日期类型的属性,但是你必须提前格式化好之后返回给它们。说真的,以前真没这样做过,之前都是一口气查询到数据,然后在jsp页面上格式化,最后展示给用户。但是这次不同,这次我纯属操作数据,没有页面。直接从数据库拿数据给它们返数据、它们给我传数据我持久化数据,说到这里一个小问题就默默的来了。

 

首先把问题还原一下吧(这是一个数据导出功能),下图中用红框圈起来的都是直接从数据库中拿到的数据,但是不幸的是它们的对象中都包含日期类型的属性,然后我直接使用com.alibaba.fastjson.JSONObject将其转成json串返回给APP端和客户端,但是他们拿到的数据中时间类型的值都是时间戳,很不人性化,我也觉的很不人性化,就答应给他们格式化一下,不料,问题来了,格式化好之后然后又设置进去,结果是没用,没用,没用,重要的事情说三遍!

解决上面出现的问题,格式化对象中的日期类型的属性值,然后返回给请求者。记住:这个动作是在服务器端完成,并且实体类和数据表中的类型也都不变,照样是日期类型的。

第一步:首先自定义一个日期类型转换器(附代码)

复制代码

 1 package com.tgsit.cjd.utils; 3 /** 4  * 日期类型转换器: 5  *         自动格式化对象中的日期类型 6  */ 8 import java.text.SimpleDateFormat; 9 import java.util.Date;10 import java.util.Locale;12 import net.sf.json.JsonConfig;13 import net.sf.json.processors.JsonValueProcessor;15 public class JsonDateValueProcessor implements JsonValueProcessor{17     private String format ="yyyy-MM-dd";  19     public JsonDateValueProcessor() {  
20         super();  
21     }    23     public JsonDateValueProcessor(String format) {  
24         super();  
25         this.format = format;  
26     } 28     @Override  
29     public Object processArrayValue(Object paramObject,  
30             JsonConfig paramJsonConfig) {  
31         return process(paramObject);  
32     }  34     @Override  
35     public Object processObjectValue(String paramString, Object paramObject,  
36             JsonConfig paramJsonConfig) {  
37         return process(paramObject);  
38     }    41     private Object process(Object value){  
42         if(value instanceof Date){    
43             SimpleDateFormat sdf = new SimpleDateFormat(format,Locale.CHINA);    
44             return sdf.format(value);  
45         }    
46         return value == null ? "" : value.toString();    
47     }  49 }

复制代码

第二步:如果项目中没有引入json-lib包,则引入

1 <dependency>2     <groupId>net.sf.json-lib</groupId>3     <artifactId>json-lib</artifactId>4     <version>2.4</version>5     <classifier>jdk15</classifier>6</dependency>

第三步:返回数据之前先使用日期类型转换器格式化日期数据

这里必须先创建JsonConfig对象,然后调用registerJsonValueProcessor(Date.class, new JsonDateValueProcessor());方法将转换器注入进去,最后在调用JsonArray的formObject(数据,new JsonConfig())方法进行处理。

注意:这里还有个小坑,就是当你处理的是单纯的一个实体对象,则直接可以jsonObject.formObject(数据,new JsonConfig());

但是你处理的一个list集合数据时,则记得用jsonArray.formObject(数据,new JsonConfig());否则报错。

 

复制代码

 1 @RequestMapping(value = "/exportInfo", method = RequestMethod.GET) 2     @ResponseBody 3     public String exportInfo(HttpServletResponse response) throws Exception{ 4         List<QueryVo> exportInfoList = queryVoService.exportInfo(); 5         if(exportInfoList != null && exportInfoList.size() > 0){ 6             List<Object> result = new ArrayList<Object>(); 7             JsonResult model = null; 8             for (QueryVo queryVo : exportInfoList) { 9                 OwnerInfo ownerInfo = ownerInfoService.selectOwnerInfoByVIN(queryVo.getVin());10                 List<MortgagerInfo> morInfoList = mortgagerInfoService.selectByVIN(queryVo.getVin());11                 List<TransferInfo> traInfoList = transferInfoService.selectByVIN(queryVo.getVin());12                 model = new JsonResult();13                 model.setOwnerInfo(ownerInfo);14                 model.setMortgagerInfo(morInfoList);15                 model.setTransferInfo(traInfoList);16                 result.add(model);17             }18             //调用自定义日期类型转换器,自动格式化对象中的日期类型的字段值19             JsonConfig jsonConfig = new JsonConfig();  
20             jsonConfig.registerJsonValueProcessor(Date.class, new JsonDateValueProcessor());21             return CGSConstants.returnJson(CGSConstants.SUCCESS,"导出成功",JSONArray.fromObject(result, jsonConfig));22         }23         return CGSConstants.returnJson(CGSConstants.SUCCESS,"尚无数据",null);24     }

复制代码