0

アプリケーションにjqueryイベントカレンダーがあり、JSON入力でフィードする必要があります。現時点では、入力は次のようになっています。

[   
{ "date": "1352636408000", "type": "meeting", "title": "Poker Freak", "description": "Lorem Ipsum dolor set", "url": "http://www.event1.com/" },    
{ "date": "1351775676000", "type": "demo", "title": "Poker Freak", "description": "Lorem ipsum dolor sit amet, cveniris nisi ut aliquip ex ea commodo consequat.", "url": "http://www.event2.com/" },   
{ "date": "1351764876000", "type": "meeting", "title": "Poker Freak", "description": "Lorem Ipsum dolor set", "url": "http://www.event3.com/" } ]

イベントカレンダーのデモファイルであるJSONファイルに保存されます。

一方、Event-Tableのデータを変換するMSSQLテーブルがあります(DateはDateTime、Typeはstringなど)。

このコマンドでデータを取得します:

        public static List<Event> GetAllEvents()
    {
        using (CyberDBDataContext db = new CyberDBDataContext())
        {
            return (from a in db.Events select a).ToList();
        }
    }

では、MSSQL Returnクエリ(イベントのリスト)をJSONに変換する方法は?

4

1 に答える 1

2

そのためには、 JSON.netライブラリを使用する必要があります。これが最も簡単な方法です (そして、私の意見では、JSON 用の最高のライブラリの 1 つです)。

これらの例の2番目と4 番目の書式を使用します

  string defaultJson = JsonConvert.SerializeObject(entry);
  // {"Details":"Application started.","LogDate":"\/Date(1234656000000)\/"}

  string javascriptJson = JsonConvert.SerializeObject(entry, new JavaScriptDateTimeConverter());
  // {"Details":"Application started.","LogDate":new Date(1234656000000)}

  string isoJson = JsonConvert.SerializeObject(entry, new IsoDateTimeConverter());
  // {"Details":"Application started.","LogDate":"2009-02-15T00:00:00Z"}

  string isoJson = JsonConvert.SerializeObject(entry, new TicksDateTimeConverter());
  // {"Details":"Application started.","LogDate":"1234656000000"}

カスタム DateFormatter を使用してスニペットをたどります。

public static string GetAllEvents()
{
    using (CyberDBDataContext db = new CyberDBDataContext())
    {
        return JsonConvert.SerializeObject((from a in db.Events select a).ToList(), new TicksDateTimeConverter());
    }
}

編集: ASP.net MVCを使用している場合

ASP.net MVC4 より前のバージョンにも適用されるかどうかはわかりませんが、バージョン 4 以降は JSON.net がデフォルトの JSON シリアライザーです。したがって、もう実装する必要はありません。

カスタム コンバーター

以下のようなカスタムコンバーターを実装することをお勧めします。基本的には JavaScript コンバーターと同じですが、Ticks のみを返す必要があります。

using System;
using System.Globalization;
using Newtonsoft.Json.Utilities;

namespace Newtonsoft.Json.Converters
{
  /// <summary>
  /// Converts a <see cref="DateTime"/> to and from a JavaScript date constructor (e.g. new Date(52231943)).
  /// </summary>
  public class TicksDateTimeConverter : DateTimeConverterBase
  {
    /// <summary>
    /// Writes the JSON representation of the object.
    /// </summary>
    /// <param name="writer">The <see cref="JsonWriter"/> to write to.</param>
    /// <param name="value">The value.</param>
    /// <param name="serializer">The calling serializer.</param>
    public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
    {
      long ticks;

      if (value is DateTime)
      {
        DateTime dateTime = (DateTime)value;
        DateTime utcDateTime = dateTime.ToUniversalTime();
        ticks = JsonConvert.ConvertDateTimeToJavaScriptTicks(utcDateTime);
      }
#if !PocketPC && !NET20
      else if (value is DateTimeOffset)
      {
        DateTimeOffset dateTimeOffset = (DateTimeOffset)value;
        DateTimeOffset utcDateTimeOffset = dateTimeOffset.ToUniversalTime();
        ticks = JsonConvert.ConvertDateTimeToJavaScriptTicks(utcDateTimeOffset.UtcDateTime);
      }
#endif
      else
      {
        throw new Exception("Expected date object value.");
      }

      writer.WriteValue(ticks);
    }

    /// <summary>
    /// Reads the JSON representation of the object.
    /// </summary>
    /// <param name="reader">The <see cref="JsonReader"/> to read from.</param>
    /// <param name="objectType">Type of the object.</param>
    /// <param name="existingValue">The existing property value of the JSON that is being converted.</param>
    /// <param name="serializer">The calling serializer.</param>
    /// <returns>The object value.</returns>
    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
    {
      Type t = (ReflectionUtils.IsNullableType(objectType))
        ? Nullable.GetUnderlyingType(objectType)
        : objectType;

      if (reader.TokenType == JsonToken.Null)
      {
        if (!ReflectionUtils.IsNullableType(objectType))
          throw new Exception("Cannot convert null value to {0}.".FormatWith(CultureInfo.InvariantCulture, objectType));

        return null;
      }

      if (reader.TokenType != JsonToken.StartConstructor || !string.Equals(reader.Value.ToString(), "Date", StringComparison.Ordinal))
        throw new Exception("Unexpected token or value when parsing date. Token: {0}, Value: {1}".FormatWith(CultureInfo.InvariantCulture, reader.TokenType, reader.Value));

      reader.Read();

      if (reader.TokenType != JsonToken.Integer)
        throw new Exception("Unexpected token parsing date. Expected Integer, got {0}.".FormatWith(CultureInfo.InvariantCulture, reader.TokenType));

      long ticks = (long)reader.Value;

      DateTime d = JsonConvert.ConvertJavaScriptTicksToDateTime(ticks);

      reader.Read();

      if (reader.TokenType != JsonToken.EndConstructor)
        throw new Exception("Unexpected token parsing date. Expected EndConstructor, got {0}.".FormatWith(CultureInfo.InvariantCulture, reader.TokenType));

#if !PocketPC && !NET20
      if (t == typeof(DateTimeOffset))
        return new DateTimeOffset(d);
#endif

      return d;
    }
  }
}
于 2012-11-16T13:50:28.050 に答える