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

博客讨论了在Java后台返回JSON数据时遇到的时间格式化问题。当后台返回Map对象,时间数据以yyyy-mm-dd HH:MM:ss字符串形式时,前台接收到的数据变成了Object。通过分析,发现一个用于格式化的类不适用于String类型的时间数据。解决方案是直接处理String类型的时间,避免进行JSONArray转换,从而成功地将时间格式化为期望的形式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

结合上一篇 :关于跨域返回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 {
	/**
	 * 字母 日期或时间元素 表示 示例 <br>
	 * G Era 标志符 Text AD <br>
	 * y 年 Year 1996; 96 <br>
	 * M 年中的月份 Month July; Jul; 07 <br>
	 * w 年中的周数 Number 27 <br>
	 * W 月份中的周数 Number 2 <br>
	 * D 年中的天数 Number 189 <br>
	 * d 月份中的天数 Number 10 <br>
	 * F 月份中的星期 Number 2 <br>
	 * E 星期中的天数 Text Tuesday; Tue<br>
	 * a Am/pm 标记 Text PM <br>
	 * H 一天中的小时数(0-23) Number 0 <br>
	 * k 一天中的小时数(1-24) Number 24<br>
	 * K am/pm 中的小时数(0-11) Number 0 <br>
	 * h am/pm 中的小时数(1-12) Number 12 <br>
	 * m 小时中的分钟数 Number 30 <br>
	 * s 分钟中的秒数 Number 55 <br>
	 * S 毫秒数 Number 978 <br>
	 * z 时区 General time zone Pacific Standard Time; PST; GMT-08:00 <br>
	 * Z 时区 RFC 822 time zone -0800 <br>
	 */

	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);

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



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











评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值