Ruby 1.9.2 リファレンスマニュアル > ライブラリ一覧 > library webrick/cgi

library webrick/cgi

要約

一般の CGI 環境で webrick ライブラリのサーブレットと同じように CGI スクリプトを書くための ライブラリです。サーバが WEBrick でなくても使うことが出来ます。

使い方

WEBrick のサーブレットを作成するのと同じように、WEBrick::CGI のサブクラスでメソッド do_GET や do_POST を定義することによって CGI スクリプトを書きます。

スクリプトの最後で WEBrick::CGI#start メソッドを呼ぶ必要があります。 WEBrick::CGI#start メソッドは service メソッドを呼び出し、service メソッドはリクエストに応じて do_XXX メソッドを呼び出します。このようにしてスクリプトは実行されます。

例:

#!/usr/local/bin/ruby
require 'webrick/cgi'

class MyCGI < WEBrick::CGI
  def do_GET(req, res)
    res["content-type"] = "text/plain"
    ret = "hoge\n"
    res.body = ret
  end
end

MyCGI.new.start()

フォームフィールドの値を得る

フォームフィールドの値は WEBrick::HTTPRequest#query メソッドが返す Hash オブジェクトに 収納されています。

require "webrick/cgi"
class MyCGI < WEBrick::CGI
  def do_GET(req, res)
    req.query               #=> Hash を返します。
    req.query['q']
    req.query['num']
  end
end
MyCGI.new.start()

同じ名前のフィールドが複数ある場合、list メソッドや each_data メソッドを使います。

require "webrick/cgi"
class MyCGI < WEBrick::CGI
  def do_GET(req, res)
    req.query['q'].list     #=> フォームの値を保持した文字列の配列を返します。
  end
end
MyCGI.new.start()

query メソッドが返す Hash オブジェクトのキーと値のうち値は WEBrick::HTTPUtils::FormData クラスの インスタンスになります。FormData クラスは String クラスのサブクラスです。

マルチパートフィールドの値を取得する(ファイル送信)

require "webrick/cgi"
class MyCGI < WEBrick::CGI
  def do_GET(req, res)
    d = req.query['field_name']   #=> FormData クラスのインスタンス
    d.name                        #=> "field_name"
    d.filename                    #=> もしあればファイル名を返す。
    d['content-type']             #=> ヘッダの値は [] メソッドで取得する
    d                             #=> 送られてきたファイルの中身
  end
end
MyCGI.new.start()

クライアントにクッキーを渡す

require "webrick/cgi"
class MyCGI < WEBrick::CGI
  def do_GET(req, res)
    c1 = WEBrick::Cookie.new("name1", "val1")
    c1.expires = Time.now + 30
    res.cookies << c1

    c2 = WEBrick::Cookie.new("name2", "val2")
    c2.expires = Time.now + 30
    res.cookies << c2
  end
end
MyCGI.new.start()

クライアントからクッキーを得る

require "webrick/cgi"
class MyCGI < WEBrick::CGI
  def do_GET(req, res)
    req.cookies                                   #=> WEBrick::Cookie オブジェクトの配列
    c = req.cookies.find{|c| c.name == "name1" }  #=> WEBrick::Cookie オブジェクト
  end
end
MyCGI.new.start()

CGI に関連する環境変数の値を取得する

CGI に関連する環境変数の値は直接 ENV から得る他に、 WEBrick::HTTPRequest オブジェクトの各メソッドから得ることができます。

require "webrick/cgi"
class MyCGI < WEBrick::CGI
  def do_GET(req, res)
    req.content_length
    req.content_type
    req.path_info
    req.query_string
    req.peeraddr
    req.host
    req.user
    req.request_method
    req.script_name
    req.port
  end
end
MyCGI.new.start()

リンク

クラスとモジュール

class WEBrick::CGI

一般の CGI 環境で WEBrick のサーブレットと同じように CGI スクリプトを書くための クラスです。

例外クラス

class WEBrick::CGI::CGIError

CGI に関係する例外クラスです。

同時にrequireされるライブラリ

webrick/config
webrick/cookie
webrick/htmlutils
webrick/httprequest
webrick/httpresponse
webrick/httpstatus

HTTP のステータスを表す例外クラスを提供します。

webrick/httputils
webrick/httpversion
webrick/log
webrick/utils

Classes

Sublibraries