zoukankan      html  css  js  c++  java
  • 时间序列化问题

    不管是Newtonsoft.Json还是微软自己的序列化器都会对时间格式进行转换,这样就会造成其他平台调用问题,有两种解决办法:

    1、将时间转换成时间戳格式,不管你是什么语言时间戳都是可以进行转换操作的,通用的

    2、将时间转换成字符串格式,间接的解决传输问题

    本人不建议使用微软自己的序列化器,有坑而且性能不咋地

    如果是将时间转换成字符串格式的话,很容易:

    string json = JsonConvert.SerializeObject(Data, new JsonSerializerSettings()
    {
        DateFormatString = "yyyy-MM-dd HH:mm:ss"
    });

    通过查看Newtonsoft.Json源代码可以发现这个:

    internal const string DefaultDateFormatString = @"yyyy'-'MM'-'dd'T'HH':'mm':'ss.FFFFFFFK";

    这个是默认的格式,所以会出现序列化时间的时候出现不一样的结果

    如果是转换成时间戳的格式就麻烦一些了,我没发现在Newtonsoft.Json可以操作,只能把数据源修改掉,举个简单的例子:

    var data = result.Data.Items.Select(m => new
    {
        m.Id,
        m.LevelName,
        m.Memo,
        m.URL,
        m.UserIP,
        m.UserId,
        OperateTime = m.OperateTime.ToTimeStamp()
    });
    
    /// <summary>
    /// 时间转换成时间戳
    /// </summary>
    /// <param name="nowTime">当前时间</param>
    /// <returns></returns>
    public static long ToTimeStamp(this DateTime nowTime)
    {
        TimeSpan ts = DateTime.UtcNow - new DateTime(1970, 1, 1, 0, 0, 0, 0);
        return Convert.ToInt64(ts.TotalSeconds);
    }

    这样操作就行了,但是比较麻烦

  • 相关阅读:
    生成缩略图时报GDI+中发生一般性错误
    跨数据库服务器查询和跨表更新
    javascript,jquery(闭包概念)
    聚集索引和非聚集索引(整理)
    ASP.NET MVC的过滤器
    如何在标题栏title前添加网站logo?
    sql语句执行顺序
    详解ASP.NET MVC的请求生命周期
    在事务中执行批量复制操作SqlBulkCopy,SqlTransaction .
    基于TCP 协议的RPC
  • 原文地址:https://www.cnblogs.com/wms01/p/6370273.html
Copyright © 2011-2022 走看看