From 54b455190b9ed9200436d9bd4967dd272576d0b7 Mon Sep 17 00:00:00 2001 From: akr Date: Fri, 8 Feb 2008 13:11:46 +0000 Subject: [PATCH] * lib/open-uri.rb (OpenURI.open_http): rescue URI::InvalidURIError by URI.parse for location URI. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15406 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ lib/open-uri.rb | 7 ++++++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 7b589d8dad..29eece08f9 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Fri Feb 8 22:10:36 2008 Tanaka Akira + + * lib/open-uri.rb (OpenURI.open_http): rescue URI::InvalidURIError by + URI.parse for location URI. + Fri Feb 8 19:22:13 2008 Nobuyoshi Nakada * ext/iconv/iconv.c (rb_str_derive): uses rb_str_subseq() for byte diff --git a/lib/open-uri.rb b/lib/open-uri.rb index 2b6cd8fd65..64b78b1217 100644 --- a/lib/open-uri.rb +++ b/lib/open-uri.rb @@ -330,7 +330,12 @@ module OpenURI Net::HTTPFound, # 302 Net::HTTPSeeOther, # 303 Net::HTTPTemporaryRedirect # 307 - throw :open_uri_redirect, URI.parse(resp['location']) + begin + loc_uri = URI.parse(resp['location']) + rescue URI::InvalidURIError + raise OpenURI::HTTPError.new(io.status.join(' ') + ' (Invalid Location URI)', io) + end + throw :open_uri_redirect, loc_uri else raise OpenURI::HTTPError.new(io.status.join(' '), io) end