[前][次][番号順一覧][スレッド一覧]

ruby-changes:3916

From: ko1@a...
Date: Fri, 8 Feb 2008 22:12:02 +0900 (JST)
Subject: [ruby-changes:3916] akr - Ruby:r15406 (trunk): * lib/open-uri.rb (OpenURI.open_http): rescue URI::InvalidURIError by

akr	2008-02-08 22:11:46 +0900 (Fri, 08 Feb 2008)

  New Revision: 15406

  Modified files:
    trunk/ChangeLog
    trunk/lib/open-uri.rb

  Log:
    * lib/open-uri.rb (OpenURI.open_http): rescue URI::InvalidURIError by
      URI.parse for location URI.


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15406&r2=15405&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/lib/open-uri.rb?r1=15406&r2=15405&diff_format=u

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 15405)
+++ ChangeLog	(revision 15406)
@@ -1,3 +1,8 @@
+Fri Feb  8 22:10:36 2008  Tanaka Akira  <akr@f...>
+
+	* 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  <nobu@r...>
 
 	* ext/iconv/iconv.c (rb_str_derive): uses rb_str_subseq() for byte
Index: lib/open-uri.rb
===================================================================
--- lib/open-uri.rb	(revision 15405)
+++ lib/open-uri.rb	(revision 15406)
@@ -330,7 +330,12 @@
          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

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]