要約
http/ftp に簡単にアクセスするためのクラスです。
使用例
http/ftp の URL を、普通のファイルのように開けます。
require 'open-uri' URI.open("http://www.ruby-lang.org/") {|f| f.each_line {|line| p line} }
開いたファイルオブジェクトは StringIO もしくは Tempfile ですが OpenURI::Meta モジュールで拡張されていて、メタ情報を獲得するメソッドが使えます。
require 'open-uri' URI.open("http://www.ruby-lang.org/en") {|f| f.each_line {|line| p line} p f.base_uri # <URI::HTTP:0x40e6ef2 URL:http://www.ruby-lang.org/en/> p f.content_type # "text/html" p f.charset # "iso-8859-1" p f.content_encoding # [] p f.last_modified # Thu Dec 05 02:45:02 UTC 2002 }
ハッシュ引数で、追加のヘッダフィールドを指定できます。
require 'open-uri' URI.open("http://www.ruby-lang.org/en/", "User-Agent" => "Ruby/#{RUBY_VERSION}", "From" => "foo@bar.invalid", "Referer" => "http://www.ruby-lang.org/") {|f| ... }
http_proxy や ftp_proxy などの環境変数は、デフォルトで有効になっています。プロキシを無効にするには :proxy => nil とします。
require 'open-uri' URI.open("http://www.ruby-lang.org/en/", :proxy => nil) {|f| ... }
また、open-uri を読み込むと URI::HTTP と URI::FTP が OpenURI::OpenRead モジュールをインクルードします。ですので、 URI オブジェクトも似たような方法で開けます。
require 'open-uri' uri = URI.parse("http://www.ruby-lang.org/en/") uri.open {|f| ... }
URI オブジェクトは直接読み込むことができます。戻り値の文字列は、OpenURI::Meta で拡張されています。
str = uri.read p str.base_uri
モジュール
OpenURI | http/ftp に簡単にアクセスするためのモジュールです。 |
OpenURI::Meta | サーバから取得したデータの属性を扱うために使われるモジュールです。データを表す文字列や StringIO が extend します。 |
OpenURI::OpenRead |
例外クラス
OpenURI::HTTPError | リソースの取得に失敗した時に投げられます。 |