我正在尝试解析一个包含括号 - [ 和 ] - 的 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,则无法应对。所以我的问题是,有没有一种不会失败的可靠方法?