在查询字符串值中使用的分隔符

问题描述 投票:21回答:8

我需要在查询字符串中接受文件名列表。即:

http://someSite/someApp/myUtil.ashx?files=file1.txt|file2.bmp|file3.doc

您对使用什么分隔符有什么建议吗?

string query-string delimiter
8个回答
14
投票

如果它们是文件名,那么一个好的选择就是文件名中不允许的字符。到目前为止的建议包括, | &,它们通常在文件名中被允许,因此可能导致含糊不清。另一方面,/通常是不被允许的,即使在Windows上也是如此。在URI中允许它,它在查询字符串中没有特殊含义。

例:

http://someSite/someApp/myUtil.ashx?files=file1.txt|file2.bmp|file3.doc很糟糕,因为它可能引用有效文件file1.txt|file2.bmp

http://someSite/someApp/myUtil.ashx?files=file1.txt/file2.bmp/file3.doc毫不含糊地指3个文件。


21
投票

多次查询参数是合法的,并且是在所有情况下保证不解析问题的唯一方法:

http://someSite/someApp/myUtil.ashx?file=file1.txt&file=file2.bmp&file=file3.doc

分号;必须是URI编码,如果文件名的一部分(转向%3B),但如果它是分隔查询参数,它是保留使用。

this rfc第2.2节:

2.2。保留字符

URI包括由“保留”集中的字符分隔的组件和子组件。这些字符称为“保留”,因为它们可能(或可能不)通过通用语法,每种特定于方案的语法或URI的解除引用算法的特定于实现的语法定义为分隔符。如果URI组件的数据与保留字符作为分隔符的目的冲突,则冲突数据必须在形成URI之前进行百分比编码。

 reserved    = gen-delims / sub-delims

 gen-delims  = ":" / "/" / "?" / "#" / "[" / "]" / "@"

 sub-delims  = "!" / "$" / "&" / "'" / "(" / ")"
             / "*" / "+" / "," / ";" / "="

7
投票

我建议让每个文件都有自己的查询参数,即

myUtil.ashx?file1=file1.txt&file2=file2.bmp&file3=file3.doc

这样您就可以使用标准查询解析和循环


6
投票

你需要将文件名列为字符串吗?大多数语言接受查询字符串中的数组,因此您可以像编写它一样编写它

http://someSite/someApp/myUtil.ashx?files[]=file1.txt&files[]=file2.bmp&files[]=file3.doc

如果没有,或者由于某些其他原因而无法使用,则应该坚持使用文件名中不允许或不常见的分隔符。管道(|)是一个很好的,否则你可以urlencode一个不可见的字符,因为它们很容易在编码中使用,但实际上包含在文件名中更难。

我通常尽可能使用数组,否则使用管道。


5
投票

我总是用双管“||”。我没有任何好的证据来支持为什么这是一个很好的选择,而不是10年的网络编程,它从来都不是问题。


1
投票

这是一个常见问题。我是如何处理它的:我创建了一个接受字符串列表的方法,然后找到了一个不在任何字符串中的字符。 (我通过字符串的简单连接,然后测试各种字符来完成此操作。)一旦找到一个字符,将所有字符串连接在一起,但也在字符串前面加上分隔字符。所以在给定的问题中,一个例子是:http://someSite/someApp/myUtil.ashx?files=|file1.txt|file2.bmp|file3.doc和另一个wud:http://someSite/someApp/myUtil.ashx?files=,file1.txt,file2.bmp,file3.doc但是因为我实际上使用的方法保证我的分隔符不在其余的字符串中,所以它是安全的。第一次创建是一项工作,但我已经在各种应用程序中使用了很多次。


0
投票

我想我会考虑使用逗号或分号。


0
投票

我会建立在MSalters的回答上说,为了概括,最好的分隔符是对列表中的项无效的分隔符。例如,如果您的列表是价格,则逗号是一个错误的分隔符,因为它可能与值混淆。出于这个原因,正如大多数这些答案所暗示的那样,我认为一个好的通用分隔符可能是“|”因为它很少是有效值。 “/”通常可能不是最好的分隔符,因为它有时对路径有效。

© www.soinside.com 2019 - 2024. All rights reserved.