C# JavaScriptSerializer序列化时的时间处理详解

这篇文章主要为大家详细介绍了C# JavaScriptSerializer序列化时的时间处理详解,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

最近被序列化困扰了一下下。原因看下面代码


class Program
 {
 static void Main(string[] args)
 {
  var user = new User { UserId = "sb", CreateDate = DateTime.Now };
  var serialier = new JavaScriptSerializer();
  var json = serialier.Serialize(user);
  Console.WriteLine(json);
  Console.Read(); 
 }
 }

 /// <summary>
 /// 用户类.
 /// </summary>
 public class User
 {
 /// <summary>
 /// 用户Id
 /// </summary>
 public string UserId { get; set; }

 /// <summary>
 /// 创建时间
 /// </summary>
 public DateTime CreateDate { get; set; }

 }

输出如下图所示:

IiBzcmM9

猜测这里是由于js初始化时间的时候往往是向 1970/01/01 添加毫秒数,JavaScriptSerializer进行序列化的时候也会格式化为距离1970/01/01 到当该时间点GMT+0 时间的毫秒数,

如果直接反序列化可以看到少了8小时,且时间精度到毫秒,原来初始化的时间精度是10-7 秒。

这种时间格式是适用于js的,但如果我们想把这个信息保存的话,这样的时间格式不适合阅读。因此需要做一下转换。

以下代码利用正则表达式将毫秒数转换成本时区的时间格式:


class Program
 {
 static void Main(string[] args)
 {
  var user = new User { UserId = "sb", CreateDate = DateTime.Now };
  var serialier = new JavaScriptSerializer();
  var json = serialier.Serialize(user);
  var jsonNomal = LocalSerialize(user);
  Console.WriteLine("js序列化:" + json);
  Console.WriteLine("本地序列化:" + jsonNomal);
  Console.Read();
 }

 public static string LocalSerialize(object obj)
 {
  var jser = new JavaScriptSerializer();
  var json = jser.Serialize(obj);
  //将时间格式转换为适合阅读习惯的格式
  json = 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;
 }
 }

 /// <summary>
 /// 用户类.
 /// </summary>
 public class User
 {
 /// <summary>
 /// 用户Id
 /// </summary>
 public string UserId { get; set; }

 /// <summary>
 /// 创建时间
 /// </summary>
 public DateTime CreateDate { get; set; }
 }

输出:

IiBzcmM9

这样就完成了转换了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程学习网。

本文标题为:C# JavaScriptSerializer序列化时的时间处理详解