Ruby 是一門通用的語言,不僅僅是一門應用於WEB開發的語言,但 Ruby 在WEB應用及WEB工具中的開發是最常見的。
使用Ruby您不僅可以編寫自己的SMTP服務器,FTP程序,或Ruby Web服務器,而且還可以使用Ruby進行CGI編程。
接下來,讓我們花點時間來學習Ruby的CGI編輯。
為了更好的了解CGI是如何工作的,我們可以從在網頁上點擊一個鏈接或URL的流程:
CGI程序可以是 Ruby 腳本,Python 腳本,PERL 腳本,SHELL 腳本,C 或者 C++ 程序等。
在你進行CGI編程前,確保您的Web服務器支持CGI及已經配置了CGI的處理程序。
Apache 支持CGI 配置:
設置好CGI目錄:
ScriptAlias /cgi-bin/ /var/www/cgi-bin/
所有的HTTP服務器執行CGI程序都保存在一個預先配置的目錄。這個目錄被稱為CGI目錄,並按照慣例,它被命名為/var/www/cgi-bin目錄。
CGI文件的擴展名為.cgi,Ruby 也可以使用 .rb 擴展名。
默認情況下,Linux服務器配置運行的cgi-bin目錄中為/var/www。
如果你想指定其他運行CGI腳本的目錄,可以修改httpd.conf配置文件,如下所示:
<Directory "/var/www/cgi-bin"> AllowOverride None Options +ExecCGI Order allow,deny Allow from all </Directory>
在 AddHandler 中添加 .rb 後綴,這樣我們就可以訪問 .rb 結尾的 Ruby 腳本文件:
AddHandler cgi-script .cgi .pl .rb
最基本的 Ruby CGI 代碼如下所示:
#!/usr/bin/ruby puts "Content-type: text/html\n\n" puts "<html><body>This is a test</body></html>"
你可以將該代碼保持到 test.cgi 文件中,上次到服務器並賦予足夠權限,即可作為 CGI 腳本執行。
如果你站的的地址為http://www.example.com/ ,即可用過http://www.example.com/test.cgi 訪問該程序,輸出結果為: "This is a test."。
浏覽器訪問該網址後,Web 服務器會在站點目錄下找到 test.cgi文件,然後通過Ruby解析器來解析腳本代碼並訪問HTML文檔。
Ruby 可以調用 CGI 庫來編寫更復雜的CGI腳本。
以下代碼調用了 CGI 庫來創建一個腳本的CGI腳本。
#!/usr/bin/ruby require 'cgi' cgi = CGI.new puts cgi.header puts "<html><body>This is a test</body></html>"
以下代碼中,創建了CGI 對象並打印頭部信息。
使用CGI庫可以通過兩種方式獲取表單提交(或URL中的參數)的數據, 例如URL:/cgi-bin/test.cgi?FirstName=Zara&LastName=Ali。
你可以使用 CGI#[] 來直接獲取參數FirstName和LastName:
#!/usr/bin/ruby require 'cgi' cgi = CGI.new cgi['FirstName'] # => ["Zara"] cgi['LastName'] # => ["Ali"]
另外一種獲取表單數據的方法:
#!/usr/bin/ruby require 'cgi' cgi = CGI.new h = cgi.params # => {"FirstName"=>["Zara"],"LastName"=>["Ali"]} h['FirstName'] # => ["Zara"] h['LastName'] # => ["Ali"]
以下代碼用於檢索所有的鍵值:
#!/usr/bin/ruby require 'cgi' cgi = CGI.new cgi.keys # => ["FirstName", "LastName"]
如果表單包含了多個相同名稱的字段,則該相同字段的值將保存在數組中。
以下實例中,指定表單中三個相同的字段"name",值分別為 "Zara", "Huma" 和 "Nuha":
#!/usr/bin/ruby require 'cgi' cgi = CGI.new cgi['name'] # => "Zara" cgi.params['name'] # => ["Zara", "Huma", "Nuha"] cgi.keys # => ["name"] cgi.params # => {"name"=>["Zara", "Huma", "Nuha"]}
注意:Ruby 會自動判斷 GET 和 POST 方法,所以無需對兩種方法區別對待。
以下是相關的HML代碼:
<html> <body> <form method="POST" action="http://www.example.com/test.cgi"> First Name :<input type="text" name="FirstName" value="" /> <br /> Last Name :<input type="text" name="LastName" value="" /> <input type="submit" value="Submit Data" /> </form> </body> </html>
CGI 包含了大量的方法來創建 HTML,每個HTML標簽都有相對應的方法。 在使用這些方法前,比必須通過 CGI.new 來創建 CGI 對象。
為了使標簽的嵌套更加的簡單,這些方法將內容作為了代碼塊,代碼塊將返回字符串作為標簽的內容。如下所示:
#!/usr/bin/ruby require "cgi" cgi = CGI.new("html4") cgi.out{ cgi.html{ cgi.head{ "\n"+cgi.title{"This Is a Test"} } + cgi.body{ "\n"+ cgi.form{"\n"+ cgi.hr + cgi.h1 { "A Form: " } + "\n"+ cgi.textarea("get_text") +"\n"+ cgi.br + cgi.submit } } } }
當你在處理 URL 中的參數或者 HTML 表單數據時,需要對指定的特殊字符進行轉義,如:引號("),反斜槓(/)。
Ruby CGI 對象提供了CGI.escape 和 CGI.unescape 方法來處理這些特殊字符的轉義:
#!/usr/bin/ruby require 'cgi' puts CGI.escape(Zara Ali/A Sweet & Sour Girl")
以上代碼執行結果如下:
#!/usr/bin/ruby require 'cgi' puts CGI.escape(Zara Ali/A Sweet & Sour Girl")
另一組實例:
#!/usr/bin/ruby require 'cgi' puts CGI.escapeHTML('<h1>Zara Ali/A Sweet & Sour Girl</h1>')
以上代碼執行結果如下:
<h1>Zara Ali/A Sweet & Sour Girl</h1>'
以下是Ruby中完整的CGI類的相關方法