2

我正在尝试解析一个包含括号 - [ 和 ] - 的 URI。我试图用 URI.parse 直接解析它,但括号导致它失败。因此,我尝试使用 CGI::escape 对 URI 进行编码,它负责处理括号,但是当我尝试使用 URI.parse 解析这个编码的 URI 时,它似乎没有将其识别为 URI 并将整个 URI 放入路径目的。

在 irb 会议上进行演示;

irb(main):001:0> require 'uri'
=> true
irb(main):002:0> require 'cgi'
=> true
irb(main):003:0> name = "http://www.website.com/dir1/dir[2]/file.txt"
=> "http://www.website.com/dir1/dir[2]/file.txt"
irb(main):004:0> encoded_name = CGI::escape(name)
=> "http%3A%2F%2Fwww.website.com%2Fdir1%2Fdir%5B2%5D%2Ffile.txt"
irb(main):005:0> parsed_name = URI.parse(encoded_name)
=> #<URI::Generic:0x00000001e8f520 URL:http%3A%2F%2Fwww.website.com%2Fdir1%2Fdir%5B2%5D%2Ffile.txt>
irb(main):006:0> parsed_name.scheme
=> nil
irb(main):007:0> parsed_name.host
=> nil
irb(main):008:0> parsed_name.path
=> "http%3A%2F%2Fwww.website.com%2Fdir1%2Fdir%5B2%5D%2Ffile.txt"
irb(main):009:0> URI.split(encoded_name)
=> [nil, nil, nil, nil, nil, "http%3A%2F%2Fwww.website.com%2Fdir1%2Fdir%5B2%5D%2Ffile.txt", nil, nil, nil]

无论如何,我目前的工作是以下丑陋但有效的黑客

encoded_name = name.gsub(/\[/,"%5B").gsub(/\]/,"%5D")

使用 URI.parse 解析它会产生所需的结果,但如果其他奇怪的字符进入我的 URI,则无法应对。所以我的问题是,有没有一种不会失败的可靠方法?

4

2 回答 2

6

问题在于试图应用于CGI::escape整个 URI。当你这样做时,你会丢失包含该方案的 URI 的前面部分,然后 URI 解析器就会丢失。您可能想根据 mtyaka 的回答尝试一些事情:

irb(main):015:0> encoded_name = URI.encode(name, '[]')
=> "http://www.website.com/dir1/dir%5B2%5D/file.txt"
irb(main):016:0> parsed_name = URI.parse(encoded_name)
=> #<URI::HTTP:0xb76ff358 URL:http://www.website.com/dir1/dir%5B2%5D/file.txt>
irb(main):017:0> parsed_name.scheme
=> "http"
irb(main):018:0> parsed_name.host
=> "www.website.com"
irb(main):019:0> parsed_name.path
=> "/dir1/dir%5B2%5D/file.txt"

要获得原始路径,URI.decode无论您从parsed_name.path.

于 2009-11-23T15:09:03.330 回答
3

你可以使用URI.encode

encoded_name = URI.encode(name, '[]')
于 2009-11-23T14:12:55.473 回答