- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个通过 toJSON 来自 javascript 的日期,所以它存储为 UTC 时间,但我想将它作为本地时间存储在数据库中(我们过去从未存储过 UTC 时间,所以我需要继续这里的趋势)。
但是,在运行 PopulateObject
时设置 DateTimeZoneHandling = Newtonsoft.Json.DateTimeZoneHandling.Local
(使用 Newtonsoft.Json 版本 6.0.0.0)不会执行任何操作,它是仍然保留为原始时间的 UTC 日期。
我的问题是:为什么它不运行 dt.ToLocalTime()
来解决问题(并且是我当前的解决方法)- 或者:如果没有,我如何让转换器执行此操作来自 DateTimeZoneHandling.Local
设置?
最佳答案
将 DateTime
作为本地时间存储到数据库中通常不是一个好主意,因为:
如果您本地的时区有 daylight saving time规则,那么您可能会丢失数据。在回退过渡期间,有一个一小时的时间段,其中本地时间可以代表两个可能的时刻。使用 UTC 可避免此问题。
它将您的数据绑定(bind)到特定位置。如果您需要将服务器迁移到另一个位置(或云端),您过去的数据将不准确。
如果您必须以本地时间存储数据,请考虑将其存储为DateTimeOffset
。通过记录偏移量,如果本地时区发生变化,您可以准确区分它所代表的唯一时间点。这足以反驳上述两点。
另请参阅:DateTime
vs DateTimeOffset
.
关于您关于 JSON.Net 和 DateTimeZoneHandling.Local
选项的问题,这个简单的示例表明它似乎按设计工作。我无法重现您的声明。
public class Foo
{
public DateTime DateTime { get; set; }
}
...
var json = "{\"DateTime\":\"2014-01-01T00:00:00.000Z\"}";
var settings = new JsonSerializerSettings
{
DateTimeZoneHandling = DateTimeZoneHandling.Local
};
var foo = JsonConvert.DeserializeObject<Foo>(json, settings);
Debug.WriteLine("{0} ({1})", foo.DateTime, foo.DateTime.Kind);
输出:
12/31/2013 16:00:00 (Local)
我的本地时区是美国太平洋时间,在提供的日期比 UTC 晚 8 小时,这反射(reflect)在结果中。
关于c# - JsonConvert 不转换 UTC -> PopulateObject 中的本地时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22812624/
编辑:澄清问题: 我已经覆盖了基类型的 JsonConverter(通过将 [JsonConverter(typeof(TConverter))] 应用于父类(super class)),但是当直接反
尝试使用 JsonConvert.PopulateObject 更新类属性时,未调用 JsonPathConverter,因此未完成填充。 示例类: [JsonConverter(typeof(Jso
我有一个我不能改变的类: public enum MyEnum { Item1 = 0, Item2 = 1 } public class foo { [JsonConvert
我正在使用 Json.NET (6.0.3) 进行序列化。我编写了一个自定义 JsonConverter TestConverter 来处理一些 BaseClass 的实例(通过将它们转换为整数 id
我有一个要求,我需要将默认值设置为下面的复杂属性 Instances使用 JsonProperty和 DefaultValue . 我知道我们可以为以下链接中提到的原始属性实现这一点,但需要知道我们如
我尝试查找上述比较,但找不到答案。 因为有多种方法可以获取 JObject(或所有继承自 JToken 的子类型)例如: Method1 . JObject.FromObject(obj); Meth
我已启用我的 API 以使用字符串值序列化/反序列化枚举。为此,我已将 JsonStringEnumConverter 添加到 API 的 Startup 类中受支持的 JsonConverter 列
我有一个 Employee 类,其中 Manager 属性本身是 Employee 类型 public class Employee { public string FirstName { g
我已经卡住模型(简化): part 'initial_data_model.freezed.dart'; part 'initial_data_model.g.dart'; @freezed clas
我正在尝试将两个字段和一个包含两个字段的捆绑对象发布到 Mailchimp 的 API 端点。 var store_id = ConfigurationManager.AppS
以下VB.NET代码使用Newtonsoft JSON.NET库,并在按钮单击事件处理程序中执行并阻止UI线程: Dim table As DataTable = Await Task.Factory
我遇到了一个问题,其中以下 ToJson() 方法返回的字符串仅为“{}” public class GenericRequest { publ
这个问题在这里已经有了答案: JSON Can't be Deserialized to Object, Needs Array? (2 个答案) 关闭 9 年前。 我有这个 Json 返回: [
我遇到了一个问题,其中以下 ToJson() 方法返回的字符串仅为“{}” public class GenericRequest { publ
这个问题在这里已经有了答案: JSON Can't be Deserialized to Object, Needs Array? (2 个答案) 关闭 9 年前。 我有这个 Json 返回: [
我创建了一个简单的类: public class TestObject { public TestObject(int id, string name, List list) {
我有一个像这样的 Json 对象: {"company": "My Company", "companyStart" : "2015/01/01", "employee" : { "name"
这是 json: { "odata.metadata": ".....", "value": [ { "AbsEntry": 10,
我有一个对象,其中包含一个具有 JsonConverter 属性的属性。对于数据读写,转换器不工作。声明的属性是 [JsonConverter(typeof(EpochDateTimeConverte
编辑:制作了一个更简单、更透明的示例案例 我正在尝试反序列化一组组件(属于一个实体)。其中一个组件是 Sprite 组件,它包含纹理和动画信息。我为此实现了一个 CustomConverter,因为原
我是一名优秀的程序员,十分优秀!