C#使用JavaScriptSerializer序列化时的时间类型处理
最近在做一个数据交换服务接口,用的 .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#教程
下一篇:C#实现简单的计算器功能完整实例
本文标题:C#使用JavaScriptSerializer序列化时的时间类型处理
本文地址:https://www.xiuzhanwang.com/a1/C_jiaocheng/5524.html
您可能感兴趣的文章
阅读排行
本栏相关
- 01-10C#通过反射获取当前工程中所有窗体并
- 01-10关于ASP网页无法打开的解决方案
- 01-10WinForm限制窗体不能移到屏幕外的方法
- 01-10WinForm绘制圆角的方法
- 01-10C#实现txt定位指定行完整实例
- 01-10WinForm实现仿视频播放器左下角滚动新
- 01-10C#停止线程的方法
- 01-10C#实现清空回收站的方法
- 01-10C#通过重写Panel改变边框颜色与宽度的
- 01-10C#实现读取注册表监控当前操作系统已
随机阅读
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-10SublimeText编译C开发环境设置
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10C#中split用法实例总结
- 04-02jquery与jsp,用jquery
- 01-11ajax实现页面的局部加载
- 01-10delphi制作wav文件的方法
- 08-05织梦dedecms什么时候用栏目交叉功能?