asp.net – 如何将一个对象序列化为查询字符串格式?

前端之家收集整理的这篇文章主要介绍了asp.net – 如何将一个对象序列化为查询字符串格式?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如何将对象序列化为查询字符串格式?我似乎找不到在谷歌的答案。谢谢。

这里是我将序列化的对象作为一个例子。

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服务器通常不会使用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深度对象的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();

猜你在找的asp.Net相关文章