如何在 AspNet Core 中处理空查询参数?
假设我们有一个查询 ?key1=foo1&key1=foo2&key2=&key3=null
在解析它时,我希望在解析这个 URL 时有某种 Dictionary> 结果,例如:
key1 : ["foo1", "foo2"] 这应该是同一个键下的多个值
key2 : [""] 这应该是一个空字符串
key3 : ["null"] 这应该是一个字符串,据我所知,URL 中的 null 只是一个文字
我的问题是:我应该如何处理空查询参数?
注意:我不能简单地定义查询参数并假设不存在的查询参数为空。但我认为如果需要,应该将 null 视为显式查询参数中的有效值。
根据这个线程:How to send NULL in HTTP query string? 标准是传递编码的空值:见https://www.w3schools.com/tags/ref_urlencode.asp
所以如果我想传递一个空值,我应该这样做: ?key1=foo1&key1=foo2&key2=&key3=%00
问题是我不知道如何解码它以便将 %00 解析为空值。
我尝试了以下方法:
public Dictionary<string, List<string>> CreateFromQuery(string query)
{
if (query == null)
{
return new Dictionary<string, List<string>>();
}
var queryDictionary = Microsoft.AspNetCore.WebUtilities.QueryHelpers.ParseQuery(query);
var result = queryDictionary.ToDictionary(kv => kv.Key, kv => kv.Value.ToList());
return result;
}
但是%00被转换成一个"\0"字符串,而不是一个null.
做一个var decodedQuery= HttpUtility.UrlDecode(query);before 似乎也没有任何区别。
UPDATE1:在 Kacper 和 Chris Pratt 发表评论(谢谢你们)之后,我现在采用了 Kacper 的第二个建议,因为我认为让请求者想要区分空查询参数、空查询参数和不存在的查询参数的场景很有趣。
所以这是我目前的实现:
public class QueryParserFactory
: IQueryParseable
{
public Dictionary<string, List<string>> CreateFromQuery(string query)
{
if (query == null)
{
return new Dictionary<string, List<string>>();
}
var queryDecoded = HttpUtility.UrlDecode(query);
var queryDictionary = QueryHelpers.ParseQuery(queryDecoded);
var result = queryDictionary
.ToDictionary(
kv => kv.Key,
kv => kv.Value.Select(s => s == "\0" ? null : s).ToList());
return result;
}
}
相关分类