我使用Stream阅读器将context.Request.InputStream
读到最后,最后得到一个类似于
"Gamestart=true&GamePlayer=8&CurrentDay=Monday&..."
在C#控制台中解析它的最有效/“干净”的方法是什么?
答案 0 :(得分:9)
您可以使用HttpUtility.ParseQueryString
小样本:
string queryString = "Gamestart=true&GamePlayer=8&CurrentDay=Monday"; //Hardcoded just for example
NameValueCollection qscoll = HttpUtility.ParseQueryString(querystring);
foreach (String k in qscoll.AllKeys)
{
//Prints result in output window.
System.Diagnostics.Debug.WriteLine(k + " = " + qscoll[k]);
}
答案 1 :(得分:3)
<强> HttpUtility.ParseQueryString 强>
使用UTF8编码将查询字符串解析为NameValueCollection。
答案 2 :(得分:0)
我知道这是一个僵尸帖子,但我想我会添加另一个答案,因为HttpUtility
添加了另一个汇编引用(System.Web
),这对某些人来说可能是不受欢迎的。
using System.Net;
using System.Text.RegularExpressions;
static readonly Regex HttpQueryDelimiterRegex = new Regex(@"\?", RegexOptions.Compiled);
static readonly Regex HttpQueryParameterDelimiterRegex = new Regex(@"&", RegexOptions.Compiled);
static readonly Regex HttpQueryParameterRegex = new Regex(@"^(?<ParameterName>\S+)=(?<ParameterValue>\S*)$", RegexOptions.Compiled);
static string GetPath(string pathAndQuery)
{
var components = HttpQueryDelimiterRegex.Split(pathAndQuery, 2);
return components[0];
}
static Dictionary<string, string> GetQueryParameters(string pathAndQuery)
{
var parameters = new Dictionary<string, string>(StringComparer.OrdinalIgnoreCase);
var components = HttpQueryDelimiterRegex.Split(pathAndQuery, 2);
if (components.Length > 1)
{
var queryParameters = HttpQueryParameterDelimiterRegex.Split(components[1]);
foreach(var queryParameter in queryParameters)
{
var match = HttpQueryParameterRegex.Match(queryParameter);
if (!match.Success) continue;
var parameterName = WebUtility.HtmlDecode(match.Groups["ParameterName"].Value) ?? string.Empty;
var parameterValue = WebUtility.HtmlDecode(match.Groups["ParameterValue"].Value) ?? string.Empty;
parameters[parameterName] = parameterValue;
}
}
return parameters;
}
我希望他们将同样的方法添加到WebUtility
中,从.NET 4.0开始,System.Net
中可以使用该方法。