Rails 跨请求对象与操作详解
1. 跨请求机制概述
重定向方法向浏览器发送响应,和渲染方法一样,每个请求只能执行一次。到目前为止,我们孤立地看待请求和响应,而 Rails 还提供了许多跨请求的机制。
1.1 跨请求的对象和操作
虽然大部分跨请求持久化的状态存储在数据库中,并通过 Active Record 访问,但有些状态有不同的生命周期,需要不同的管理方式。例如在某些应用中,购物车对象存储在数据库中,但当前购物车的信息由会话管理;闪存通知用于在重定向后将消息传递到下一个请求;回调用于从 URL 中提取区域设置数据。
2. Rails 会话
2.1 会话的基本概念
Rails 会话是一种类似哈希的结构,可跨请求持久化。与原始 cookie 不同,会话可以保存任何可序列化的对象,非常适合在 Web 应用中保存状态信息。例如在商店应用中,使用会话在请求之间保存购物车对象。Rails 会在每个请求处理结束时保存购物车,并在处理新请求时恢复正确的购物车。
2.2 会话数据的存储位置
- 客户端 cookie :这是 Rails 的默认选项。服务器将数据作为 cookie 发送到客户端,内容默认加密,用户无法查看或篡改。但这种方式有大小限制(总计 4KB),且会增加带宽,但服务器管理和清理的工作较少。
- 服务器端 :设置较为复杂,通常不太必要。Rails 会创建一个 32 位十六进制字符的会话 ID 作为 cookie 存储在用户浏览器中,后续请求可通过该 ID 恢
超级会员免费看
订阅专栏 解锁全文
26

被折叠的 条评论
为什么被折叠?



