Ruby - CGI 会话



CGI::Session 在 CGI 环境中为 Web 用户维护持久状态。会话在使用后应关闭,因为这确保了其数据被写入存储。当您永久完成一个会话时,您应该删除它。

#!/usr/bin/ruby

require 'cgi'
require 'cgi/session'
cgi = CGI.new("html4")

sess = CGI::Session.new( cgi, "session_key" => "a_test", "prefix" => "rubysess.")
lastaccess = sess["lastaccess"].to_s
sess["lastaccess"] = Time.now
if cgi['bgcolor'][0] =~ /[a-z]/
   sess["bgcolor"] = cgi['bgcolor']
end

cgi.out {
   cgi.html {
      cgi.body ("bgcolor" => sess["bgcolor"]) {
         "The background of this page"    +
         "changes based on the 'bgcolor'" +
         "each user has in session."      +
         "Last access time: #{lastaccess}"
      }
   }
}

访问“/cgi-bin/test.cgi?bgcolor = red”将使页面对于每个连续点击的单个用户变为红色,直到通过 URL 指定新的“bgcolor”。

会话数据存储在每个会话的临时文件中,并且 prefix 参数分配一个要附加到文件名开头的字符串,这使得您的会话易于在服务器的文件系统上识别。

CGI::Session 仍然缺少许多功能,例如存储除字符串以外的对象的能力、跨多个服务器的会话存储。

类 CGI::Session

CGI::Session 在 CGI 环境中为 Web 用户维护持久状态。会话可以驻留在内存中,也可以存储在磁盘上。

类方法

Ruby 类 Class CGI::Session 提供单个类方法来创建会话 -

CGI::Session::new( cgi[, option])

启动新的 CGI 会话并返回相应的 CGI::Session 对象。option 可以是指定以下一个或多个选项的选项哈希 -

  • session_key - 存储会话 ID 的键名。默认为 _session_id。

  • session_id - 唯一的会话 ID。自动生成

  • new_session - 如果为真,则为本次会话创建一个新的会话 ID。如果为假,则使用由 session_id 标识的现有会话。如果省略,则如果可用则使用现有会话,否则创建一个新的会话。

  • database_manager - 用于保存会话的类;可以是 CGI::Session::FileStore 或 CGI::Session::MemoryStore。默认为 FileStore。

  • tmpdir - 对于 FileStore,会话文件的目录。

  • prefix - 对于 FileStore,会话文件名的前缀。

实例方法

序号 方法和描述
1

[ ]

返回给定键的值。请参阅上面的示例。

2

[ ]=

设置给定键的值。请参阅上面的示例。

3

delete

调用底层数据库管理器的 delete 方法。对于 FileStore,删除包含会话的物理文件。对于 MemoryStore,从内存中删除会话。

4

update

调用底层数据库管理器的 update 方法。对于 FileStore,将会话数据写入磁盘。对 MemoryStore 没有影响。

ruby_web_applications.htm
广告