1. ホーム
  2. asp.net

[解決済み] オブジェクトをクエリ文字列形式にシリアライズするには?

2023-04-19 20:53:35

質問

オブジェクトをクエリ文字列形式にシリアライズするにはどうしたらよいでしょうか。googleで調べても答えが見つからないようです。ありがとうございます。

例として、私がシリアライズするオブジェクトを示します。

public class EditListItemActionModel
{
    public int? Id { get; set; }
    public int State { get; set; }
    public string Prefix { get; set; }
    public string Index { get; set; }
    public int? ParentID { get; set; }
}

どのように解決するのですか?

このための組み込みのユーティリティ メソッドがないことは 99% 確実です。これはあまり一般的なタスクではなく、Web サーバーは通常 に応答します。 というのは、Web サーバーは通常、URLEncoded キー/値文字列で応答しないからです。

リフレクションとLINQを混ぜるのはどうでしょうか?これはうまくいきます。

var foo = new EditListItemActionModel() {
  Id = 1,
  State = 26,
  Prefix = "f",
  Index = "oo",
  ParentID = null
};

var properties = from p in foo.GetType().GetProperties()
                 where p.GetValue(foo, null) != null
                 select p.Name + "=" + HttpUtility.UrlEncode(p.GetValue(foo, null).ToString());

// queryString will be set to "Id=1&State=26&Prefix=f&Index=oo"                  
string queryString = String.Join("&", properties.ToArray());

更新します。

任意の1-deepオブジェクトのQueryString表現を返すメソッドを書くには、次のようにします。

public string GetQueryString(object obj) {
  var properties = from p in obj.GetType().GetProperties()
                   where p.GetValue(obj, null) != null
                   select p.Name + "=" + HttpUtility.UrlEncode(p.GetValue(obj, null).ToString());

  return String.Join("&", properties.ToArray());
}

// Usage:
string queryString = GetQueryString(foo);

また、あまり追加作業をせずに、拡張メソッドにすることもできます。

public static class ExtensionMethods {
  public static string GetQueryString(this object obj) {
    var properties = from p in obj.GetType().GetProperties()
                     where p.GetValue(obj, null) != null
                     select p.Name + "=" + HttpUtility.UrlEncode(p.GetValue(obj, null).ToString());

    return String.Join("&", properties.ToArray());
  }
}

// Usage:
string queryString = foo.GetQueryString();