我有以下 URI:http://host/path?param1=1¶m2[]=2¶m3[1]=3
uri.getQueryParameterNames() 返回一个包含预期值 ["param1", "param2[]", "param3[1]"] 的数组。
但是当将这些值传递给 getQueryParameter 时,我得到: uri.getQueryParameter("param1") == "1" uri.getQueryParameter("param2[]") == null uri.getQueryParameter("param3[1]") == null
我试过在没有括号部分的情况下传递参数名称,但它也不起作用。调用 getQueryParameters() 也不起作用。
谢谢你的帮助!
最佳答案
如 documentation 中所述, Uri 构建并解析符合 RFC 2396 的 URI 引用.
如果向下滚动到规范中的第 2.4.3 节,您会发现以下内容:
Other characters are excluded because gateways and other transport
agents are known to sometimes modify such characters, or they are
used as delimiters.
unwise = "{" | "}" | "|" | "\" | "^" | "[" | "]" | ""`Data corresponding to excluded characters must be escaped in order to be properly represented within a URI.
从代码的角度来看,Uri 有一个私有(private)方法来判断一个字符是否被允许——如果不允许,它将被编码。理论上,这应该为括号和其他特殊字符返回 false。
/**
* Returns true if the given character is allowed.
*
* @param c character to check
* @param allow characters to allow
* @return true if the character is allowed or false if it should be
* encoded
*/
private static boolean isAllowed(char c, String allow) {
return (c >= 'A' && c <= 'Z')
|| (c >= 'a' && c <= 'z')
|| (c >= '0' && c <= '9')
|| "_-!.~'()*".indexOf(c) != NOT_FOUND
|| (allow != null && allow.indexOf(c) != NOT_FOUND);
}
话虽如此,现在我们到了有趣的部分。看起来 Uri.parse() 相当“懒惰”,因为它实际上并不对您提供的 uri 进行编码。在您的场景中,您可能正在通过调用构建 Uri:
Uri uri = Uri.parse("http://host/path?param1=1¶m2[]=2¶m3[1]=3");
然后当您开始对生成的 Uri 调用 getQueryParameter() 时,会发生的是支持数据(String)是 ' unencoded',但是您提供给这些方法的参数名称确实得到了编码。例如:
uri.getQueryParameter("param2[]")
实际上是:
uri.getQueryParameter("param2%5B%5D")
带有关键字 param2%5B%5D 的查询参数显然不存在于 Uri 中。
解决方案是确保首先对括号进行转义,或者使用 Uri.Builder。例如:
Uri uri = Uri.parse("http://host/path").buildUpon()
.appendQueryParameter("param1", "1")
.appendQueryParameter("param2[]", "2")
.appendQueryParameter("param3[1]", "3")
.build();
这将导致以下基础 uri:
http://host/path?param1=1¶m2%5B%5D=2¶m3%5B1%5D=3
然后您可以毫无问题地调用 uri.getQueryParameter("param3[1]"):它将返回 3。
编辑:我收回关于 Uri.parse() 懒惰的说法。它的目的是这样的。正如 Javadoc 中明确提到的那样:
Creates a Uri which parses the given encoded URI string.
换句话说:您提供的用于解析的字符串应该已经正确编码。
关于android - Uri.getQueryParameter() 不适用于 "["和 "]"符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18281593/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub
我在新的Debian6VirtualBoxVM上安装RVM时遇到问题。我已经安装了所有需要的包并使用下载了安装脚本(curl-shttps://rvm.beginrescueend.com/install/rvm)>rvm,但以单个用户身份运行时bashrvm我收到以下错误消息:ERROR:Unabletocheckoutbranch.安装在这里停止,并且(据我所知)没有安装RVM的任何文件。如果我以root身份运行脚本(对于多用户安装),我会收到另一条消息:Successfullycheckedoutbranch''安装程序继续并指示成功,但未添加.rvm目录,甚至在修改我的.bas