私の場合、WP7 ではユーティリティHttpUtility.ParseQueryStringを使用できないため、Url を解析する必要がありました。そこで、次のような拡張メソッドを作成しました。
public static class UriExtensions
{
private static readonly Regex queryStringRegex;
static UriExtensions()
{
queryStringRegex = new Regex(@"[\?&](?<name>[^&=]+)=(?<value>[^&=]+)");
}
public static IEnumerable<KeyValuePair<string, string>> ParseQueryString(this Uri uri)
{
if (uri == null)
throw new ArgumentException("uri");
var matches = queryStringRegex.Matches(uri.OriginalString);
for (int i = 0; i < matches.Count; i++)
{
var match = matches[i];
yield return new KeyValuePair<string, string>(match.Groups["name"].Value, match.Groups["value"].Value);
}
}
}
次に、たとえば、それを使用する問題です
var uri = new Uri(HttpUtility.UrlDecode(@"file.aspx?userId=123§ion=2"),UriKind.RelativeOrAbsolute);
var parameters = uri.ParseQueryString().ToDictionary( kvp => kvp.Key, kvp => kvp.Value);
var userId = parameters["userId"];
var section = parameters["section"];
注:辞書の代わりに IEnumerable を直接返すのは、パラメーターの名前が重複している可能性があると想定しているからです。重複した名前がある場合、ディクショナリは例外をスローします。