关于JSON数据格式返回时间数据格式化问题

结合上一篇 :关于跨域返回jsonp的示例

首先看两张图,分别是前后后打断点监测到的数据

java后台数据:




图说明,后台java返回一个List,这个list是联合多表查询,返回的数据为map对象,并非javaBean对象;


前台断点:


图说明,前台获取的json时间数据格式为:



问题:后台返回map对象,时间数据格式为yyyy-mm-dd HH:MM:ss格式的字符串,返回前台即成为object对象。网上查找原因,找到一个关于后台返回Json数据格式时间格式化的类,这个类如下:

/**
 * @FileName: DateJsonValueProcessor.java
 * @Description: TODO(Json数据时间格式转化类)
 * @Copyright: Copyright(C) 2010-2015 All rights Reserved
 * @Company: ShenZhen  Information Technology Co.,LTD.
 * @author: neil
 * @version V1.0 
 * @Createdate: 2015-11-3
 *
 * Modification  History:
 * Date         Author        Version        Discription
 * -----------------------------------------------------------------------------------
 * 2015-11-3       NEIL          1.0             1.0
 * Why & What is modified: <修改原因描述>
 */
package com.common.util;

import java.security.Timestamp;
import java.text.DateFormat;
import java.text.SimpleDateFormat;

import net.sf.json.JsonConfig;
import net.sf.json.processors.JsonValueProcessor;

public class DateJsonValueProcessor implements JsonValueProcessor {
	/**
	 * 字母 日期或时间元素 表示 示例 
* G Era 标志符 Text AD
* y 年 Year 1996; 96
* M 年中的月份 Month July; Jul; 07
* w 年中的周数 Number 27
* W 月份中的周数 Number 2
* D 年中的天数 Number 189
* d 月份中的天数 Number 10
* F 月份中的星期 Number 2
* E 星期中的天数 Text Tuesday; Tue
* a Am/pm 标记 Text PM
* H 一天中的小时数(0-23) Number 0
* k 一天中的小时数(1-24) Number 24
* K am/pm 中的小时数(0-11) Number 0
* h am/pm 中的小时数(1-12) Number 12
* m 小时中的分钟数 Number 30
* s 分钟中的秒数 Number 55
* S 毫秒数 Number 978
* z 时区 General time zone Pacific Standard Time; PST; GMT-08:00
* Z 时区 RFC 822 time zone -0800
*/ public static final String Default_DATE_PATTERN = "yyyy-MM-dd"; private DateFormat dateFormat; public DateJsonValueProcessor(String datePattern) { try { dateFormat = new SimpleDateFormat(datePattern); } catch (Exception e) { dateFormat = new SimpleDateFormat(Default_DATE_PATTERN); } } @Override public Object processArrayValue(Object value, JsonConfig jsonConfig) { // TODO Auto-generated method stub return process(value); } @Override public Object processObjectValue(String key, Object value, JsonConfig jsonConfig) { // TODO Auto-generated method stub return process(value); } private Object process(Object value) { if (value == null) { return ""; } else { return dateFormat.format((Timestamp) value); } } }

使用方法,在action里注册config配置,如下:

JsonConfig config = new JsonConfig();
config.registerJsonValueProcessor(Timestamp.class,new DateJsonValueProcessor("yyyy-MM-dd HH:mm:ss"));
List list = gisDataBusiness.getRealList();
rows = JSONArray.fromObject(list,config);


如果想用此类达到时间格式化的目的,在config.registerJsonValueProcessor(arg1,arg2),两个参数中,arg1为时间格式类型,arg2为格式化;arg1可以为Timestamp.class或者是Date.class;因此,如果后台返回的是javaBean对象,数据中如果有时间,必定是这二个之一,但这个例子中,返回的数据时间为Sting,所以并不能使用这个类作为时间格式化工具。

在上一篇中已经讲到跨域返回json数据问题,里面对于数据封装是这样的:

JSONArray rows = JSONArray.fromObject(list);  
jsonObject.put("RESULTSET", rows);  
HttpServletRequest request = ServletActionContext.getRequest();  
HttpServletResponse response = ServletActionContext.getResponse();  
response.setContentType("text/javascript");  


在这里作一小改动,因为在这里后台已经直接返回String类型数据,所以这里不再作JSONArray类型转换,改为如下:

JSONObject jsonObject = new JSONObject();			
List list = gisDataBusiness.getRealList();
jsonObject.put("RealList", list);

这样,再次调试前端页面,得到如下结果:



时间已经乖乖变回来了,成功!











你可能感兴趣的:(框架,json,jsonp,javascript,框架,struts2,action,JSON)