🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
# Ruby CGI Sessions CGI::Session 可以为用户和CGI环境保存持久的会话状态,会话使用后需要关闭,这样可以保证数据写入到存储当中,当会话完成后,你需要删除该数据。 ``` #!/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" 将跳转到指定背景颜色的页面。 会话数据存在在服务器的临时文件目录中,prefix 参数指定了会话的前缀,将作为临时文件的前缀。这样你在服务器上可以轻松的识别不同的会话临时文件。 ## CGI::Session 类 CGI::Session 保持了用户与 CGI 环境的持久状态。 会话可以在内存中,也可以在硬盘上。 ### 类方法 Ruby 类 Class CGI::Session 提供了简单的方法来创建 session: ``` CGI::Session::new( cgi[, option]) ``` 启用一个新的 CGI 会话并返回相应的 CGI::Session 对象。选项可以是可选的哈希,可以是以下值: * **session_key:** 键名保存会话 默认为 _session_id。 * **session_id:** 唯一的会话 ID。自动生成 * **new_session:** 如果为true,为当前会话创建一个新的Session id。 如果为 false, 通过 session_id 使用已存在的 session 标识。 如果省略该参数,如果可用则使用现有的会话,否则创建一个新的。 * **database_manager:** 用于保存 sessions 的类,可以是 CGI::Session::FileStore or CGI::Session::MemoryStore。默认为 FileStore。 * **tmpdir:** 对于 FileStore, 为 session 的错存储目录。 * **prefix:** 对于 FileStore, 为 session 文件的前缀。 ### 实例化方法 | 方法 | 描述 | | --- | --- | | **[ ]** | 返回给定 key 的值。查看实例。 | | **[ ]=** | 设置给定 key 的值。 查看实例。 | | **delete** | 调用底层数据库管理的删除方法。对于 FileStore, 删除包含 session 的物理文件。 对于 MemoryStore, 从内存中移除 session 数据。 | | **update** | 调用底层数据库管理的更新方法。 对于 FileStore, 将 session 写入到磁盘中。 对于 MemoryStore则无效果。 |