欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# JavaScriptSerializer序列化時的時間處理詳解

 更新時間:2017年08月26日 10:56:42   作者:流氓呆呆  
這篇文章主要為大家詳細介紹了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>
 /// 創(chuàng)建時間
 /// </summary>
 public DateTime CreateDate { get; set; }

 }

輸出如下圖所示:

猜測這里是由于js初始化時間的時候往往是向 1970/01/01 添加毫秒數,JavaScriptSerializer進行序列化的時候也會格式化為距離1970/01/01 到當該時間點GMT+0 時間的毫秒數,

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

這種時間格式是適用于js的,但如果我們想把這個信息保存的話,這樣的時間格式不適合閱讀。因此需要做一下轉換。

以下代碼利用正則表達式將毫秒數轉換成本時區(qū)的時間格式:

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>
 /// 創(chuàng)建時間
 /// </summary>
 public DateTime CreateDate { get; set; }
 }

輸出:

這樣就完成了轉換了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論