Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >开心档-软件开发入门之Ruby CGI Cookie

开心档-软件开发入门之Ruby CGI Cookie

原创
作者头像
爱学iOS的小麦子
发布于 2023-02-06 09:15:48
发布于 2023-02-06 09:15:48
47100
代码可运行
举报
文章被收录于专栏:iOS开发大全iOS开发大全
运行总次数:0
代码可运行

作者简介:每天分享Ruby 数组(Array)教程的学习经验、和学习笔记。

座右铭:有自制力,做事有始有终;学习能力强,愿意不断地接触学习新知识。

个人主页:爱学iOS的小麦子的主页​​​​​​

前言

本章将会讲解Ruby CGI Cookie

Ruby CGI Cookie

HTTP协议是无状态协议。但对于一个商业网站,它需要保持不同的页面间的会话信息。

如用户在网站注册过程中需要跳转页面,但又要保证之前填写的信息不丢失。

这种情况下 Cookie 很好的帮我们解决了问题。


Cookie 是如何工作的?

几乎所有的网站设计者在进行网站设计时都使用了Cookie,因为他们都想给浏览网站的用户提供一个更友好的、人文化的浏览环境,同时也能更加准确地收集访问者的信息。

写入和读取

Cookies集合是附属于Response对象及Request对象的数据集合,使用时需要在前面加上Response或Request。

用于给客户机发送Cookies的语法通常为:

当给不存在的Cookies集合设置时,就会在客户机创建,如果该Cookies己存在,则会被代替。由于Cookies是作为HTTP传输的头信息的一部分发给客户机的,所以向客户机发送Cookies的代码一般放在发送给浏览器的HTML文件的标记之前。

如果用户要读取Cookies,则必须使用Request对象的Cookies集合,其使用方法是: 需要注意的是,只有在服务器未被下载任何数据给浏览器前,浏览器才能与Server进行Cookies集合的数据交换,一旦浏览器开始接收Server所下载的数据,Cookies的数据交换则停止,为了避免错误,要在程序和前面加上response.Buffer=True。

集合的属性

  • **1.Expires属性:**此属性用来给Cookies设置一个期限,在期限内只要打开网页就可以调用被保存的Cookies,如果过了此期限Cookies就自动被删除。如: 设定Cookies的有效期到2004年4月1日,到时将自动删除。如果一个Cookies没有设定有效期,则其生命周期从打开浏览器开始,到关闭浏览器结束,每次运行后生命周期将结束,下次运行将重新开始。
  • **2.Domain属性:**这个属性定义了Cookies传送数据的唯一性。若只将某Cookies传送给_blank">搜狐主页时,则可使用如下代码:
  • **3.Path属性:**定义了Cookies只发给指定的路径请求,如果Path属性没有被设置,则使用应用软件的默认路径。
  • **4.Secure属性:**指定Cookies能否被用户读取。
  • **5、Name=Value :**Cookies是以键值对的形式进行设置和检索的。

Ruby 中处理Cookies

你可以创建一个名为 cookie 的对象并存储文本信息,将该信息发送至浏览器,调用 CGI.out 设置cookie的头部:

实例

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#!/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值,如下所示:

实例

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#!/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对象实例化时包含以下参数:

参数

描述

name

规定 cookie 的名称。

value

规定 cookie 的值。

expire

规定 cookie 的有效期。

path

规定 cookie 的服务器路径。

domain

规定 cookie 的域名。

secure

规定是否通过安全的 HTTPS 连接来传输 cookie。

上一篇

Ruby 块

下一篇

Ruby CGI方法

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
开心档-软件开发入门之Ruby CGI方法
你可以再 CGI 实例中使用相应的 HTML 标签名来创建 HTML 标签,实例如下:
爱学iOS的小麦子
2023/02/06
8000
服务端(.Net)如何操作Cookies?
【摘要】Cookie是浏览器支持的,以键值对的方式存储变量和值,并保存至客户端的文本对象。通常在前端我们使用JavaScript能够很方便地操作Cookie。但是,有时候我们在服务端也需要对保存在客户端的Cookie进行操作,比如进行身份验证等。那么,基于.NET技术,在服务端我们如何操作Cookie呢?
高一峰
2020/09/22
1.6K0
cookie是什么?
Cookie 并不是它的原意“甜饼”的意思, 而是一个保存在客户机中的简单的文本文件, 这个文件与特定的 Web 文档关联在一起, 保存了该客户机访问这个Web 文档时的信息, 当客户机再次访问这个 Web 文档时这些信息可供该文档使用。由于“Cookie”具有可以保存在客户机上的神奇特性, 因此它可以帮助我们实现记录用户个人信息的功能, 而这一切都不必使用复杂的CGI等程序 [2] 。 举例来说, 一个 Web 站点可能会为每一个访问者产生一个唯一的ID, 然后以 Cookie 文件的形式保存在每个用户的机器上。如果使用浏览器访问 Web, 会看到所有保存在硬盘上的 Cookie。在这个文件夹里每一个文件都是一个由“名/值”对组成的文本文件,另外还有一个文件保存有所有对应的 Web 站点的信息。在这里的每个 Cookie 文件都是一个简单而又普通的文本文件。透过文件名, 就可以看到是哪个 Web 站点在机器上放置了Cookie(当然站点信息在文件里也有保存) [2] 。
meowrain
2021/04/22
5650
cookie是什么?
Python开发中的cookie 学习
cookie :是用户保存在用户浏览器端的一对键值对,是为了解决http的无状态连接。服务端是可以把 cookie写到用户浏览器上,用户每次发请求会携带cookie。 存放位置: 每次发请求cookie是放在请求头里面的。 应用场景:
py3study
2020/01/06
3960
Python开发中的cookie 学习
开心档-软件开发入门之Ruby CGI Session
CGI::Session 可以为用户和CGI环境保存持久的会话状态,会话使用后需要关闭,这样可以保证数据写入到存储当中,当会话完成后,你需要删除该数据。
爱学iOS的小麦子
2023/02/06
3920
五分钟带你了解Cookie、Session、Token 和 JWT
根据上图可以看到,从用户请求发起,到服务端完成操作,流程颇多,但是HTTP无状态,我们如何才能详细记录这些操作过程并加以严格的权限判断控制,接下来就开始今天的主题!
周三不加班
2019/09/03
1.2K0
五分钟带你了解Cookie、Session、Token 和 JWT
[JavaEE笔记]Cookie
静默虚空
2018/01/05
1.7K0
一文搞明白Cookie、Session与Token
HTTP 协议是一种无状态协议,即每次服务端接收到客户端的请求时,都是一个全新的请求,服务器并不知道客户端的历史请求记录;Session 和 Cookie 的主要目的就是为了弥补 HTTP 的无状态特性
中龙技术
2022/09/30
1.7K0
一文搞明白Cookie、Session与Token
以登录注册理解Cookie的作用过程
在登录成功的一瞬间,需要后台设置一个Cookie,记录一下登陆的用户id(这里用邮箱表示,代码在上面),然后发响应给浏览器 例如在服务器端设置响应头:set-cookies:user_email=1@mtt.com
代码之风
2018/10/31
1.8K0
会话跟踪技术之Cookie
Cookie介绍 背景 HTTP协议是无状态协议,无状态是指每次request请求之前是相互独立的,当前请求并不会记录它的上一次请求信息 问题:既然无状态,那完成一套完整的业务逻辑,需要发送多次请求,那么怎么标识这些请求都是同一个浏览器操作呢? 解决方案 当浏览器发送request请求到服务器,服务器除了返回请求的response之外,还给请求分配一个唯一标识ID和response一并返回给浏览器 服务器在本地创建一个map结构,专门以key-value存储这个ID标识和浏览器的关系 当浏览器第一次请求后已
高大北
2022/06/14
6070
会话跟踪技术之Cookie
Cookie和Session区别及原理
1)通过 HttpServletRequest 的 getSession() 方法获取。该方法具有两个重载的方法。
Java微观世界
2025/01/21
1710
Cookie和Session区别及原理
Tornado(cookie、XSRF、用户验证)
——————–Cookie操作——————– 1、设置Cookie 1、set_cookie(name,value,domain=None,expires=None,path=”/”)
全栈程序员站长
2022/08/31
8110
开心档之C++ Web 编程
为了更好地了解 CGI 的概念,让我们点击一个超链接,浏览一个特定的网页或 URL,看看会发生什么。
爱学iOS的小麦子
2023/10/14
2520
web渗透测试—-33、HttpOnly[通俗易懂]
HttpOnly是微软公司的Internet Explorer 6 SP1引入的一项新特性。这个特性为cookie提供了一个新属性,用以阻止客户端脚本访问Cookie,至今已经称为一个标准,几乎所有的浏览器都会支持HttpOnly。 下面示例显示了HTTP响应标头中HttpOnly使用的语法:
全栈程序员站长
2022/09/07
2.7K0
Session&Cookie
http协议是基于请求与响应的无状态协议,但是进行使用时,通常会进行多次的请求与响应,将多次的请求与响应当做一个会话(浏览器窗口没有关闭)
张哥编程
2024/12/13
1210
Session&Cookie
面试中的cookies、session、token
一般在面试的时候,经常会被问到关于什么是cookies、session、token,大多数面试官可以通过这几个概念基本上了解到你对接口请求方面是否了解或者工作中掌握的熟练程度。
FunTester
2023/08/04
2610
面试中的cookies、session、token
理解Cookie和Session机制
会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话。常用的会话跟踪技术是Cookie与Session。Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端记录信息确定用户身份。
哲洛不闹
2018/09/18
1.3K0
理解Cookie和Session机制
vue之Cookie
Cookie的使用必须基于web服务器,因为Cookie的操作会跟随http请求进行。 Cookie,有时也用其复数形式 Cookies。类型为“小型文本文件”,是某些网站为了辨别用户身份,进行Session跟踪而储存在用户本地终端上的数据(通常经过加密),由用户客户端计算机暂时或永久保存的信息。 Cookie 并不是它的原意“甜饼”的意思,而是一个保存在客户机中的简单的文本文件,这个文件与特定的 Web 文档关联在一起,保存了该客户机访问这个Web 文档时的信息,当客户机再次访问这个 Web 文档时这些信息可供该文档使用。由于“Cookie”具有可以保存在客户机上的神奇特性,因此它可以帮助我们实现记录用户个人信息的功能,而这一切都不必使用复杂的CGI等程序 。 举例来说,一个 Web 站点可能会为每一个访问者产生一个唯一的ID,然后以 Cookie 文件的形式保存在每个用户的机器上。如果使用浏览器访问 Web,会看到所有保存在硬盘上的 Cookie。在这个文件夹里每一个文件都是一个由“名/值”对组成的文本文件,另外还有一个文件保存有所有对应的 Web 站点的信息。在这里的每个 Cookie 文件都是一个简单而又普通的文本文件。透过文件名,就可以看到是哪个 Web 站点在机器上放置了Cookie(当然站点信息在文件里也有保存) 。 Cookie是一段不超过4KB的小型文本数据,由一个名称(Name)、一个值(Value)和其它几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。
张哥编程
2024/12/13
1660
vue之Cookie
登录状态控制:cookies对比sessionStorage保持信息的分析
之前在《cookie跨域传输cookie问题:nginx跨域代理之proxy_cookie_domain 》,再次摘要
周陆军博客
2023/05/07
7020
cookie面面观
在前端面试中,有一个必问的问题:请你谈谈cookie和localStorage有什么区别啊?
前端林子
2018/09/08
3K0
cookie面面观
相关推荐
开心档-软件开发入门之Ruby CGI方法
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验