为什么Map中Date类型数据接收时变为Long类型数据

阅读更多
问题描述

接口调试过程中,发现调用同一个SQL的两个不同的Service返回值不一致

问题分析

代码跟踪,对比两处调用的位置:
1.以map作为参数
2.以po类作为参数,再将po中属性取出放入map
后者正确而前者错误

问题解决

与项目的结构有关,从上层逐步跟踪分析,结论如下:
1.web project 与 core(核心server 以及 dao 操作) project
2.调用时通过 HTTP请求的 core 部署的服务器地址,通过URI的映射,请求指定的接口,将参数传递过去,application / json 参数有一个json  的转换过程
3.问题定位到JSON 中的值得转化

问题模拟

通过JSON格式化Map进行输出
Map map = new HashMap(2);
map.put("date", new Date());
// import com.alibaba.fastjson.JSON;
String str = JSON.toJSONString(map);
// {"date":1506317028289}
System.out.println(str);


问题结论

JSON格式化过程中将Date自动转为Long
在使用此类型的数据时,需要再将其由Long转为Date
或参照
http://blog.csdn.net/zhang289202241/article/details/71173001
http://www.cnblogs.com/hdwpdx/p/5332591.html
进行解决

触类旁通

AJAX提交数据时同样有此问题,传递的Date类型数据,在接收时会被转为Long

你可能感兴趣的:(Map)