代码改变世界

C# 中使用 JavaScriptSerializer 序列化时的时间类型处理

2017-08-25 17:50  我的小小熊  阅读(543)  评论(0编辑  收藏  举报

  最近在做一个数据交换服务接口,用的 .NET Web API 项目。需要监控每次请求的数据,也就是操作日志。请求数据为实体对象,所以我用了序列化将请求内容读取并写入日志。咋一看,好像并没有什么问题,但是时间却不是我们平常看到的格式。效果图是这样的:

    

  猜测这里是由于 js 初始化时间的时候往往是向 1970/01/01 添加毫秒数,JavaScriptSerializer 进行序列化的时候也会格式化为距离 1970/01/01  到当前时间点 GMT+0 时间的毫秒数,如果直接反序列化可以看到少了8小时,且时间精度到毫秒,原来初始化的时间精度是 10-7 秒。

  这种时间格式是使用于 js 的,但如果我们想把这个信息保存的话,这样的时间格式不适合阅读。因此需要做一下转换。以下代码利用正则表达式将毫秒数转换成本时区的时间格式:

     /// <summary>
        /// 序列化请求数据
        /// </summary>
        /// <param name="obj">请求数据</param>
        /// <returns></returns>
        public  string LocalSerialize(object obj)
        {
            var jser = new System.Web.Script.Serialization.JavaScriptSerializer();
            var json = jser.Serialize(obj);
            //将时间格式转换为适合阅读习惯的格式
            json = System.Text.RegularExpressions.Regex.Replace(json, @"\\/Date\((\d+)\)\\/", match =>
            {
                DateTime dt = new DateTime(1970, 1, 1);
                dt = dt.AddMilliseconds(long.Parse(match.Groups[1].Value));
                dt = dt.ToLocalTime(); //本地时间
                return dt.ToString(); ;
            });
            return json;
        }

  然后再调用该方法就可以了。完成后的效果图:

    

  至此完成了转换。本文参考 http://www.cnblogs.com/basterdaidai/p/6212760.html