C#使用JavaScriptSerializer序列化时的时间类型处理
程序员文章站
2023-12-15 21:13:28
最近在做一个数据交换服务接口,用的 .net web api 项目。需要监控每次请求的数据,也就是操作日志。请求数据为实体对象,所以我用了序列化将请求内容读取并写入日志。咋...
最近在做一个数据交换服务接口,用的 .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; }
然后再调用该方法就可以了。完成后的效果图:
至此完成了转换。
本文参考:c# javascriptserializer序列化时的时间处理详解
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
C#使用JavaScriptSerializer序列化时的时间类型处理
-
C# JavaScriptSerializer序列化时的时间处理详解
-
C#使用JavaScriptSerializer序列化时的时间类型处理
-
Python时间序列处理之ARIMA模型的使用讲解
-
C# 关于使用JavaScriptSerializer 序列化与返序列化的操作
-
Newtonsoft.Json C# Json序列化和反序列化工具的使用、类型方法大全
-
使用JSON JavaScriptSerializer进行反序列化和序列化时报错,字符的长度超出了MaxJsonLength的长度
-
C# 关于使用JavaScriptSerializer 序列化与返序列化的操作
-
Newtonsoft.Json C# Json序列化和反序列化工具的使用、类型方法大全
-
使用JSON JavaScriptSerializer进行反序列化和序列化时报错,字符的长度超出了MaxJsonLength的长度