Ruby CGI 操作 Cookie
HTTP 协议是无状态协议
但每个网站,都需要保持不同的页面间的会话信息
如用户在网站注册过程中需要跳转页面,但又要保证之前填写的信息不丢失,这种情况下 Cookie 很好的帮我们解决了问题。
Cookie 是如何工作的?
几乎所有的网站设计者在进行网站设计时都使用了Cookie,因为他们都想给浏览网站的用户提供一个更友好的、人文化的浏览环境,同时也能更加准确地收集访问者的信息。
写入和读取
Cookies 集合是附属于 Response 对象及 Request 对象的数据集合,使用时需要在前面加上 Response 或 Request
用于给客户机发送 Cookies 的语法通常为:
当给不存在的 Cookie s集合设置时,就会在客户机创建,如果该 Cookies 己存在,则会被代替。
由于 Cookies 是作为 HTTP 传输的头信息的一部分发给客户机的,所以向客户机发送 Cookies 的代码一般放在发送给浏览器的HTML文件的标记之前。
如果用户要读取Cookies,则必须使用Request对象的Cookies集合,其使用方法是: 需要注意的是,只有在服务器未被下载任何数据给浏览器前,浏览器才能与Server进行Cookies集合的数据交换,一旦浏览器开始接收Server所下载的数据,Cookies的数据交换则停止,为了避免错误,要在程序和前面加上response.Buffer=True
集合的属性
-
Expires属性: 此属性用来给Cookies设置一个期限,在期限内只要打开网页就可以调用被保存的Cookies,如果过了此期限Cookies就自动被删除
如:设定Cookies的有效期到2020年4月1日,到时将自动删除
如果一个Cookies 没有设定有效期,则其生命周期从打开浏览器开始,到关闭浏览器结束,每次运行后生命周期将结束,下次运行将重新开始。
-
Domain属性: 这个属性定义了 Cookies 传送数据的唯一性
-
Path属性: 定义了Cookies只发给指定的路径请求,如果Path属性没有被设置,则使用应用软件的缺省路径。
-
Secure属性: 指定Cookies能否被用户读取
- Name=Value : Cookies是以键值对的形式进行设置和检索的
Ruby 语言处理 Cookies
我们通过创建一个名为 cookie 的对象并存储文本信息,然后该信息发送至浏览器
CGI.out 方法可以用来设置 cookie 的头部
cookie_set.cgi
# !/usr/bin/ruby -w # -*- encoding:utf-8 -*- # filename: cookie_set.cgi # author: 简单教程(www.twle.cn) # Copyright © 2015-2065 www.twle.cn. All rights reserved. require "cgi" cgi = CGI.new("html5") 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
然后我们再写一个 CGI 脚本,用来查找 cookie 值
cookie_get.cgi
# !/usr/bin/ruby -w # -*- encoding:utf-8 -*- # filename: cookie_get.cgi # author: 简单教程(www.twle.cn) # Copyright © 2015-2065 www.twle.cn. All rights reserved. require "cgi" cgi = CGI.new("html5") cookie = cgi.cookies['mycookie'] cgi.out('cookie' => cookie) do cgi.head + cgi.body { cookie[0] } end
CGI::Cookie 实例化时包含以下参数
参数 | 描述 |
---|---|
name | 规定 cookie 的名称 |
value | 规定 cookie 的值 |
expire | 规定 cookie 的有效期 |
path | 规定 cookie 的服务器路径 |
domain | 规定 cookie 的域名 |
secure | 规定是否通过安全的 HTTPS 连接来传输 cookie |