Вопрос

  

Возможный дубликат:
   Как преобразовать метку времени UNIX в DateTime и наоборот?

У меня есть следующий класс:

[DataContractAttribute]
public class TestClass
{
  [DataMemberAttribute]
  public DateTime MyDateTime { get; set; }
}

Вот JSON:

{ "MyDateTime":"1221818565" }

JSON возвращается из веб-службы PHP.

Что мне нужно сделать, так это преобразовать эту эпохальную строку в допустимый C # DateTime. Какой лучший способ сделать это?

Я могу сделать это:

[IgnoreDataMemberAttribute]
public DateTime MyDateTime { get; set; }

[DataMemberAttribute(Name = "MyDateTime")]
public Int32 MyDateTimeTicks
{
  get { return this.MyDateTime.Convert(...); }
  set { this.Created = new DateTime(...); }
}

Но проблема в том, что MyDateTimeTicks является общедоступным (изменение его на частное вызывает исключение в процессе сериализации)

Это было полезно?

Решение

Завершение того, что вы опубликовали, и сделав его приватным, мне показалось хорошо.

[DataContract]
public class TestClass
{

    private static readonly DateTime unixEpoch = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);

    [IgnoreDataMember]
    public DateTime MyDateTime { get; set; }

    [DataMember(Name = "MyDateTime")]
    private int MyDateTimeTicks
    {
        get { return (int)(this.MyDateTime - unixEpoch).TotalSeconds; }
        set { this.MyDateTime = unixEpoch.AddSeconds(Convert.ToInt32(value)); }
    }

}

Другие советы

private DateTime ConvertJsonStringToDateTime(string jsonTime)
        {
            if (!string.IsNullOrEmpty(jsonTime) && jsonTime.IndexOf("Date") > -1)
            {
                string milis = jsonTime.Substring(jsonTime.IndexOf("(") + 1);
                string sign = milis.IndexOf("+") > -1 ? "+" : "-";
                string hours = milis.Substring(milis.IndexOf(sign));
                milis = milis.Substring(0, milis.IndexOf(sign));
                hours = hours.Substring(0, hours.IndexOf(")"));
                return new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc).AddMilliseconds(Convert.ToInt64(milis)).AddHours(Convert.ToInt64(hours) / 100);                 
            }

            return DateTime.Now;
        }

Вот что я придумала. В C # похоже, что вам нужно создать новый DateTime и добавить значение эпохи в виде «секунд» к этому DateTime. Вот как это выглядит в коде:

new System.DateTime(1970, 1, 1, 0, 0, 0, 0).AddSeconds(1221818565);

При использовании непосредственного окна Visual Studio я распечатал результат этой операции на консоли отладчика:

{9/19/2008 10:02:45 AM}
    Date: {9/19/2008 12:00:00 AM}
    Day: 19
    DayOfWeek: Friday
    DayOfYear: 263
    Hour: 10
    Kind: Unspecified
    Millisecond: 0
    Minute: 2
    Month: 9
    Second: 45
    Ticks: 633574153650000000
    TimeOfDay: {10:02:45}
    Year: 2008

Я знаю, что ваш вопрос касался PHP, но я просто хотел отметить " gotcha " для .NET JSON. Похоже, что .NET дает вам дату в «миллисекундах с начала эпохи». (в отличие от секунд). В этом случае строка AddSeconds должна быть: <Код> unixEpoch.AddMilliseconds (Int64.Parse (дата));

Дополнительная информация: http://blogs.msdn.com/b/marcelolr/archive/2008/03/05/system-datetime-ticks-vs-json-date.aspx

Вам нужно следующее:

DateTime unixEpoch = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);
DateTime dotnetTime = unixEpoch.AddSeconds(Convert.ToDouble(ticks));

где ticks - это значение, переданное вам PHP.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top