webdevqa.jp.net

.NETでクエリ文字列を解析してNameValueCollectionにする方法

p1=6&p2=7&p3=8などの文字列を解析してNameValueCollectionにしたいと思います。

Page.Requestオブジェクトにアクセスできないときにこれを行う最もエレガントな方法は何ですか?

181
Nathan Smith

このための組み込み.NETユーティリティがあります。 HttpUtility.ParseQueryString

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

querystringnew Uri(fullUrl).Queryに置き換える必要がある場合があります。

348
Guy Starbuck

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);
   }
}
43
Scott Dorman

System.Web への回答の依存関係が受け入れられているため、多くの回答がカスタム例を提供しています。 Microsoft.AspNet.WebApi.Client NuGetパッケージには riExtensions.ParseQueryString があり、これも使用できます。

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

したがって、 System.Web 依存関係を回避し、独自のロールを行いたくない場合、これは適切なオプションです。

25
James Skimming

「クライアントのみのフレームワークサブセット」に限定された前提条件を持ちながら、ClickOnce展開のクエリ文字列を解析できるように、System.Webへの依存関係を削除したかったのです。

私は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;
    }
19
densom

OLSCクエリを操作するときに既に提供されていた機能よりも少し汎用性の高い機能が必要でした。

  • 値には複数の等号を含めることができます
  • 名前と値の両方でエンコードされた文字をデコードします
  • クライアントフレームワークで実行可能
  • Mobile Frameworkで実行できます。

私の解決策は次のとおりです。

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

Uri自体に機能を追加するために<Extension()>に取り組むことも悪い考えではないかもしれません。

7
Josh Brown

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

7
jvenema

Web API Client にはParseQueryStringで動作し、Uriを返すHttpValueCollection拡張メソッドがあることがわかりました。

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

HttpUtility.ParseQueryString を使用する必要があるSystem.Webへの依存を回避したい場合は、System.Net.HttpにあるUri拡張メソッドParseQueryStringを使用できます。 。

プロジェクトのSystem.Net.Httpに参照を追加してください(まだ行っていない場合)。

UriSystem.Net.Http内)が機能するように、応答本文を有効なParseQueryStringに変換する必要があることに注意してください。

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();
2
    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 ] );    
            }    
        }
    }
2
rp.

Request.QueryStringにアクセスするだけです。別の答えとして言及されたAllKeysは、単にキーの配列を取得します。

1
Bloodhound

System.Web依存関係が必要ない場合は、HttpUtilityクラスからこのソースコードを貼り付けてください。

これを Mono のソースコードからまとめました。 HttpUtilityとそのすべての依存関係(IHtmlString、Helpers、HttpEncoder、HttpQSCollectionなど)が含まれています。

次に、HttpUtility.ParseQueryStringを使用します。

https://Gist.github.com/bjorn-ALi-goransson/b04a7c44808bb2de8cca3fc9a3762f9c

1
user3638471

HttpUtility.ParseQueryString(Request.Url.Query)戻り値はHttpValueCollection(内部クラス)です。 NameValueCollectionから継承します。

    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); 
1
alex1kirch

誰もが彼のソリューションを貼り付けているようだから..これは私のものです:-)保存されたハイパーリンクからIDパラメータを取得するためにSystem.Webのないクラスライブラリ内からこれが必要でした。

このソリューションはより速く、見栄えが良いので、共有したいと思いました。

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")
1
Tiele Declercq

すべてのクエリ文字列パラメーターのNameValueCollectionのRequest.QueryString.Keysを見つけます。

0
Mark Glorie
        var q = Request.QueryString;
        NameValueCollection qscoll = HttpUtility.ParseQueryString(q.ToString());
0
Hamit YILDIRIM

すべてのクエリ文字列値を取得するには、これを試してください:

    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
0
mirko cro 1234