Ruby CGI Cookie

HTTP協(xié)議是無狀態(tài)協(xié)議。但對于一個商業(yè)網(wǎng)站,它需要保持不同的頁面間的會話信息。

如用戶在網(wǎng)站注冊過程中需要跳轉(zhuǎn)頁面,但又要保證之前填寫的信息不丟失。

這種情況下 Cookie 很好的幫我們解決了問題。

Cookie 是如何工作的?

幾乎所有的網(wǎng)站設(shè)計(jì)者在進(jìn)行網(wǎng)站設(shè)計(jì)時(shí)都使用了Cookie,因?yàn)樗麄兌枷虢o瀏覽網(wǎng)站的用戶提供一個更友好的、人文化的瀏覽環(huán)境,同時(shí)也能更加準(zhǔn)確地收集訪問者的信息。

寫入和讀取

Cookies集合是附屬于Response對象及Request對象的數(shù)據(jù)集合,使用時(shí)需要在前面加上Response或Request。

用于給客戶機(jī)發(fā)送Cookies的語法通常為:

當(dāng)給不存在的Cookies集合設(shè)置時(shí),就會在客戶機(jī)創(chuàng)建,如果該Cookies己存在,則會被代替。由于Cookies是作為HTTP傳輸?shù)念^信息的一部分發(fā)給客戶機(jī)的,所以向客戶機(jī)發(fā)送Cookies的代碼一般放在發(fā)送給瀏覽器的HTML文件的標(biāo)記之前。

如果用戶要讀取Cookies,則必須使用Request對象的Cookies集合,其使用方法是: 需要注意的是,只有在服務(wù)器未被下載任何數(shù)據(jù)給瀏覽器前,瀏覽器才能與Server進(jìn)行Cookies集合的數(shù)據(jù)交換,一旦瀏覽器開始接收Server所下載的數(shù)據(jù),Cookies的數(shù)據(jù)交換則停止,為了避免錯誤,要在程序和前面加上response.Buffer=True。

集合的屬性

  • 1.Expires屬性:此屬性用來給Cookies設(shè)置一個期限,在期限內(nèi)只要打開網(wǎng)頁就可以調(diào)用被保存的Cookies,如果過了此期限Cookies就自動被刪除。如: 設(shè)定Cookies的有效期到2004年4月1日,到時(shí)將自動刪除。如果一個Cookies沒有設(shè)定有效期,則其生命周期從打開瀏覽器開始,到關(guān)閉瀏覽器結(jié)束,每次運(yùn)行后生命周期將結(jié)束,下次運(yùn)行將重新開始。

  • 2.Domain屬性:這個屬性定義了Cookies傳送數(shù)據(jù)的唯一性。若只將某Cookies傳送給_blank">搜狐主頁時(shí),則可使用如下代碼:

  • 3.Path屬性:定義了Cookies只發(fā)給指定的路徑請求,如果Path屬性沒有被設(shè)置,則使用應(yīng)用軟件的默認(rèn)路徑。

  • 4.Secure屬性:指定Cookies能否被用戶讀取。

  • 5、Name=Value : Cookies是以鍵值對的形式進(jìn)行設(shè)置和檢索的。

Ruby 中處理Cookies

你可以創(chuàng)建一個名為 cookie 的對象并存儲文本信息,將該信息發(fā)送至瀏覽器,調(diào)用 CGI.out 設(shè)置cookie的頭部:

在線示例

#!/usr/bin/ruby
 
require "cgi"
cgi = CGI.new("html4")
cookie = CGI::Cookie.new('name' => 'mycookie',
                         'value' => 'Zara Ali',
                         'expires' => Time.now + 3600)
cgi.out('cookie' => cookie) do
   cgi.head + cgi.body { "Cookie stored" }
end

接下來我們回到這個頁面,并查找cookie值,如下所示:

在線示例

#!/usr/bin/ruby
 
require "cgi"
cgi = CGI.new("html4")
cookie = cgi.cookies['mycookie']
cgi.out('cookie' => cookie) do
   cgi.head + cgi.body { cookie[0] }
end

CGI::Cookie對象示例化時(shí)包含以下參數(shù):

參數(shù)描述
name指定 cookie 的名稱。
value指定 cookie 的值。
expire指定 cookie 的有效期。
path指定 cookie 的服務(wù)器路徑。
domain指定 cookie 的域名。
secure指定是否通過安全的 HTTPS 連接來傳輸 cookie。
丰满人妻一级特黄a大片,午夜无码免费福利一级,欧美亚洲精品在线,国产婷婷成人久久Av免费高清