[英]How to extract params from JSON edpoint url in Ruby on Rails?
[英]How to extract URL parameters from a URL with Ruby or Rails?
我有一些网址,例如
http://www.example.com/something?param1=value1¶m2=value2¶m3=value3
我想从这些 URL 中提取参数并将它们放入哈希中。 显然,我可以使用正则表达式,但我只是想知道使用 Ruby 或 Rails 是否有更简单的方法来做到这一点。 我在 Ruby 模块URI
没有找到任何东西,但也许我错过了一些东西。
事实上,我需要一种方法来做到这一点:
extract_parameters_from_url("http://www.example.com/something?param1=value1¶m2=value2¶m3=value3")
#=> {:param1 => 'value1', :param2 => 'value2', :param3 => 'value3'}
你有什么建议吗?
我想你想把任何给定的URL字符串变成HASH吗?
您可以尝试http://www.ruby-doc.org/stdlib/libdoc/cgi/rdoc/classes/CGI.html#M000075
require 'cgi'
CGI::parse('param1=value1¶m2=value2¶m3=value3')
回报
{"param1"=>["value1"], "param2"=>["value2"], "param3"=>["value3"]}
我发现自己最近的项目需要同样的东西。 在Levi的解决方案的基础上,这是一个更清洁,更快的方法:
Rack::Utils.parse_nested_query 'param1=value1¶m2=value2¶m3=value3'
# => {"param1"=>"value1", "param2"=>"value2", "param3"=>"value3"}
刚刚改进Levi回答 -
Rack::Utils.parse_query URI("http://example.com?par=hello&par2=bye").query
对于像上面的url这样的字符串,它将返回
{ "par" => "hello", "par2" => "bye" }
对于纯Ruby解决方案,将URI.parse
与CGI.parse
组合在一起(即使不需要Rails / Rack等,也可以使用它):
CGI.parse(URI.parse(url).query)
# => {"name1" => ["value1"], "name2" => ["value1", "value2", ...] }
解决问题的方法不止一种。 其他人向你展示了一些技巧。 我知道另一个技巧。 这是我的尝试: -
require 'uri'
url = "http://www.example.com/something?param1=value1¶m2=value2¶m3=value3"
uri = URI(url)
# => #<URI::HTTP:0x89e4898 URL:http://www.example.com/something?param1=value1¶m2=value2¶m3=value3>
URI::decode_www_form(uri.query).to_h # if you are in 2.1 or later version of Ruby
# => {"param1"=>"value1", "param2"=>"value2", "param3"=>"value3"}
Hash[URI::decode_www_form(uri.query)] # if you are below 2.1 version of Ruby
# => {"param1"=>"value1", "param2"=>"value2", "param3"=>"value3"}
查看可寻址的 gem - Ruby的URI模块的流行替代品,使查询解析变得容易:
require "addressable/uri"
uri = Addressable::URI.parse("http://www.example.com/something?param1=value1¶m2=value2¶m3=value3")
uri.query_values['param1']
=> 'value1'
(与URI不同,它显然也处理param编码/解码)
你也可以用这个方法
require 'uri'
require 'cgi'
uri = URI("https://example.com/?query=1&q=2&query=5")
a = CGI::parse(uri.query)
puts a #=> {"query"=>["1", "5"], "q"=>["2"]}
puts a["query"].to_s #=> ["1", "5"]
puts a["query"][0] #=> 1
puts a["query"][1] #=> 5
puts a["q"][0] #=> 2
它安全且容易得多
遗憾的是,当尝试从有问题的 URL 中提取查询参数时, URI
和addressable
库都会中断。 例如,这打破了两者:
http://localhost:4300/webapp/foo/#//controller/action?account=001-001-111&email=john%40email.com
基于 Arthur / Levi 的解决方案,使用url.split("?").try(:last)
您可以只获取 URL 的查询参数部分,并使用Rack::Utils.parse_nested_query
将该参数字符串解析为哈希。
或全文:
Rack::Utils.parse_nested_query(url.split("?").try(:last))
在我的例子中返回:
{"account": "001-001-111", "email": "john@email.com"}
在 Ruby 2.7/3 中使用 CGI 可能是一种过时的方法。
这是使用 URI 执行此操作的一种巧妙方法:
uri = URI.parse 'https://duckduckgo.com/?q=ruby+programming+language'
params = Hash[URI.decode_www_form uri.query]
# => {"q"=>"ruby programming language"}
在Controller中,您应该能够访问名为params
的字典(哈希)。 所以,如果你知道每个查询参数的名称是什么,那么只需要执行params[:param1]
来访问它...如果你不知道参数的名称是什么,你可以遍历字典并获得键。
一些简单的例子在这里 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.