如何将查询stringparsing为.NET中的NameValueCollection

我想parsing一个string,如p1=6&p2=7&p3=8到一个NameValueCollection

当你不能访问Page.Request对象时,最优雅的方法是什么?

这里有一个内置的.NET工具: HttpUtility.ParseQueryString

 // C# NameValueCollection qscoll = HttpUtility.ParseQueryString(querystring); 
 ' VB.NET Dim qscoll As NameValueCollection = HttpUtility.ParseQueryString(querystring) 

您可能需要用new Uri(fullUrl).Queryreplacequerystring

HttpUtility.ParseQueryString将工作,只要你在一个Web应用程序或不介意包括对System.Web的依赖。 另一种方法是:

 NameValueCollection queryParameters = new NameValueCollection(); string[] querySegments = queryString.Split('&'); foreach(string segment in querySegments) { string[] parts = segment.Split('='); if (parts.Length > 0) { string key = parts[0].Trim(new char[] { '?', ' ' }); string val = parts[1].Trim(); queryParameters.Add(key, val); } } 

很多答案都提供了自定义的例子,因为接受的答案依赖于System.Web 。 从Microsoft.AspNet.WebApi.Client NuGet包有一个UriExtensions.ParseQueryString ,也可以使用的方法:

 var uri = new Uri("https://stackoverflow.com/a/22167748?p1=6&p2=7&p3=8"); NameValueCollection query = uri.ParseQueryString(); 

所以,如果你想避免System.Web的依赖性,不想推出自己的,这是一个不错的select。

我想删除对System.Web的依赖关系,以便我可以parsingClickOnce部署的查询string,同时具有仅限于“仅客户端框架子集”的先决条件。

我喜欢RP的答案。 我添加了一些额外的逻辑。

 public static NameValueCollection ParseQueryString(string s) { NameValueCollection nvc = new NameValueCollection(); // remove anything other than query string from url if(s.Contains("?")) { s = s.Substring(s.IndexOf('?') + 1); } foreach (string vp in Regex.Split(s, "&")) { string[] singlePair = Regex.Split(vp, "="); if (singlePair.Length == 2) { nvc.Add(singlePair[0], singlePair[1]); } else { // only one key with no value specified in query string nvc.Add(singlePair[0], string.Empty); } } return nvc; } 

我需要的function比OLSC查询时已经提供的function多一点。

  • 值可能包含多个等号
  • 在名称和值中解码编码的字符
  • 能够在Client Framework上运行
  • 能够在Mobile Framework上运行。

这是我的解决scheme:

 Public Shared Function ParseQueryString(ByVal uri As Uri) As System.Collections.Specialized.NameValueCollection Dim result = New System.Collections.Specialized.NameValueCollection(4) Dim query = uri.Query If Not String.IsNullOrEmpty(query) Then Dim pairs = query.Substring(1).Split("&"c) For Each pair In pairs Dim parts = pair.Split({"="c}, 2) Dim name = System.Uri.UnescapeDataString(parts(0)) Dim value = If(parts.Length = 1, String.Empty, System.Uri.UnescapeDataString(parts(1))) result.Add(name, value) Next End If Return result End Function 

把这个function添加到Uri本身也不是一个坏主意。

要做到这一点没有System.Web ,没有自己写,而没有额外的NuGet包:

  1. 添加对System.Net.Http.Formatting的引用
  2. 添加using System.Net.Http;
  3. 使用此代码:

     new Uri(uri).ParseQueryString() 

https://msdn.microsoft.com/en-us/library/system.net.http.uriextensions(v=vs.118).aspx

  private void button1_Click( object sender, EventArgs e ) { string s = @"p1=6&p2=7&p3=8"; NameValueCollection nvc = new NameValueCollection(); foreach ( string vp in Regex.Split( s, "&" ) ) { string[] singlePair = Regex.Split( vp, "=" ); if ( singlePair.Length == 2 ) { nvc.Add( singlePair[ 0 ], singlePair[ 1 ] ); } } } 

我只是意识到, Web API客户端有一个ParseQueryString扩展方法在Uri上工作,并返回一个HttpValueCollection

 var parameters = uri.ParseQueryString(); string foo = parameters["foo"]; 

只要访问Request.QueryString。 AllKeys提到另一个答案只是让你一个键arrays。

HttpUtility.ParseQueryString(Request.Url.Query)返回的是HttpValueCollection (内部类)。 它从NameValueCollectioninheritance。

  var qs = HttpUtility.ParseQueryString(Request.Url.Query); qs.Remove("foo"); string url = "~/Default.aspx"; if (qs.Count > 0) url = url + "?" + qs.ToString(); Response.Redirect(url); 

如果您不想要System.Web依赖项,只需粘贴来自HttpUtility类的源代码即可。

我只是从Mono的源代码中把它们一起扯到一起。 它包含HttpUtility及其所有依赖项(如IHtmlString,Helpers,HttpEncoder,HttpQSCollection)。

然后使用HttpUtility.ParseQueryString

https://gist.github.com/bjorn-ali-goransson/b04a7c44808bb2de8cca3fc9a3762f9c

因为每个人似乎都在粘贴他的解决scheme..这里是我的:-)我需要从一个类库内没有System.Web从存储的超链接获取ID参数。

以为我会分享,因为我觉得这个解决scheme更快,更好看。

 public static class Statics public static Dictionary<string, string> QueryParse(string url) { Dictionary<string, string> qDict = new Dictionary<string, string>(); foreach (string qPair in url.Substring(url.IndexOf('?') + 1).Split('&')) { string[] qVal = qPair.Split('='); qDict.Add(qVal[0], Uri.UnescapeDataString(qVal[1])); } return qDict; } public static string QueryGet(string url, string param) { var qDict = QueryParse(url); return qDict[param]; } } 

用法:

 Statics.QueryGet(url, "id") 

为所有查询string参数的NameValueCollection创buildRequest.QueryString.Keys。

要获取所有的查询string值,请尝试以下操作:

  Dim qscoll As NameValueCollection = HttpUtility.ParseQueryString(querystring) Dim sb As New StringBuilder("<br />") For Each s As String In qscoll.AllKeys Response.Write(s & " - " & qscoll(s) & "<br />") Next s 
  var q = Request.QueryString; NameValueCollection qscoll = HttpUtility.ParseQueryString(q.ToString()); 

如果要避免使用HttpUtility.ParseQueryString所需的System.Web依赖项,则可以使用System.Net.HttpUri扩展方法ParseQueryString

确保在项目中添加一个引用(如果你还没有)到System.Net.Http

请注意,您必须将响应正文转换为有效的Uri以便ParseQueryString (在System.Net.Http )工作。

 string body = "value1=randomvalue1&value2=randomValue2"; // "http://localhost/query?" is added to the string "body" in order to create a valid Uri. string urlBody = "http://localhost/query?" + body; NameValueCollection coll = new Uri(urlBody).ParseQueryString(); 

我在VB中翻译成C#版本的josh-brown

 private System.Collections.Specialized.NameValueCollection ParseQueryString(Uri uri) { var result = new System.Collections.Specialized.NameValueCollection(4); var query = uri.Query; if (!String.IsNullOrEmpty(query)) { var pairs = query.Substring(1).Split("&".ToCharArray()); foreach (var pair in pairs) { var parts = pair.Split("=".ToCharArray(), 2); var name = System.Uri.UnescapeDataString(parts[0]); var value = (parts.Length == 1) ? String.Empty : System.Uri.UnescapeDataString(parts[1]); result.Add(name, value); } } return result; } 

这是我的代码,我认为这非常有用:

 public String GetQueryString(string ItemToRemoveOrInsert = null, string InsertValue = null ) { System.Collections.Specialized.NameValueCollection filtered = new System.Collections.Specialized.NameValueCollection(Request.QueryString); if (ItemToRemoveOrInsert != null) { filtered.Remove(ItemToRemoveOrInsert); if (!string.IsNullOrWhiteSpace(InsertValue)) { filtered.Add(ItemToRemoveOrInsert, InsertValue); } } string StrQr = string.Join("&", filtered.AllKeys.Select(key => key + "=" + filtered[key]).ToArray()); if (!string.IsNullOrWhiteSpace(StrQr)){ StrQr="?" + StrQr; } return StrQr; }