基于Django的电子商务网站开发(连载7)

简介: HTTP是一种无状态协议,每个请求独立,不保存会话信息,这使得服务器响应更快但需重复传输信息。为解决无状态问题,引入了Cookie和Session技术。Cookie可存储用户登录信息和购物车数据,实现便捷登录和跨页面数据保存;Session则通过服务器保存会话信息,客户端仅存储SessionId,实现更安全的状态管理。这两种方法共同解决了Web应用程序中状态保持的问题。

1.3.5 HTTP的无状态

通信中无状态协议是指同一个会话的连续两个请求互相不了解,它们由最新实例化的环境进行解析,除了应用本身可能已经存储在全局对象中的所有信息外,该环境不保存与会话有关的任何信息。

HTTP是一个无状态协议,这意味着每个请求都是独立的,Keep-Alive不能改变这个结果。

缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在服务器不需要先前信息时它的应答就较快。

HTTP协议这种特性即有优点也有缺点,优点在于服务器得到了解放,每一次请求“点到为止”不会造成不必要连接占用,缺点在于每次请求会传输大量重复的内容信息。

进行动态交互的Web应用程序出现之后,HTTP无状态的性质严重阻碍了这些应用程序的实现,这是因为交互是需要承前启后的,比如“购物车”的程序就要知道用户到底在之前选择了什么商品。这样,两种用于保持 HTTP 连接状态的技术就应运而生了,它们分别是Cookie和Session。

Cookie可以保持登录信息到用户下次与服务器的会话,用户可以这次登录,而下次登录不需要输入用户名和密码。而还有一些Cookie在用户退出会话的时候就被删除了,这样可以有效保护个人隐私(这种cookie叫做非持久型cookie,具有固定会话期限的cookie叫做持久型cookie)。

Cookie最典型的应用是判定注册用户是否已经登录了网站,用户可能会得到提示,是否在下一次进入此网站时保留用户信息以便简化登录手续,这些都是Cookie的功用。另一个重要应用场合是“购物车”之类处理。用户可能会在一段时间内在同一家网站的不同页面中选择不同的商品,这些信息都会写入 Cookie,以便在最后付款时提取信息。图1-13为网易126邮箱网站通过Cookie保持登录选项。图1-14 京东网站中购物车中内容的显示。

图1-13 126网站通过Cookie保持登录选项

图1-14 京东网站中购物车中内容的显示

与 Cookie另外一个解决方案就是Session,它是通过服务器来保持状态的。

当客户端访问服务器的时候,服务器会根据需求设置Session,将会话信息保存在服务器上,同时将标示 Session 的 SessionId 传送给客户端浏览器,浏览器将这个SessionId保存在客户端的内存中,称之为没有过期时间的Cookie。当浏览器关闭后,这个Cookie就会被清掉,它不会存在于用户的Cookie临时文件。

以后浏览器每次请求都会额外加上这个参数值,服务器会根据这个SessionId,就能取得客户端的数据信息。

如果客户端浏览器意外发生关闭,服务器保存的Session数据是不会立即释放的,这个时候数据还会存在,只要知道那个SessionId,就可以继续通过请求获得此 Session的信息,因为此时后台的Session还存在,当然可以设置一个Session超时时间,一旦超过规定时间没有客户端请求时,服务器就会清除对应SessionId的Session信息。

目录
相关文章
|
6天前
|
存储 前端开发 数据库
基于Django的电子商务网站开发(连载10)
本节介绍了用户信息模块,涵盖用户注册、登录、信息展示及密码修改功能。重点描述了用户注册流程,包括urls.py配置、forms.py中的表单定义及views.py中的处理逻辑。通过详细代码示例展示了如何实现用户信息验证与存储,并提供了注册页面的模板设计。特别强调了使用`request.POST.get`方法以支持后续接口测试。图3-2展示了实际的注册页面效果。
15 2
基于Django的电子商务网站开发(连载10)
|
6天前
|
网络协议 应用服务中间件 Apache
基于Django的电子商务网站开发(连载6)
HTTP协议最初设计为无连接协议,每次请求完成后断开连接以节省资源。但随着网页复杂度增加,频繁建立连接效率低下,因此HTTP 1.1引入了Keep-Alive机制,维持客户端与服务器间的连接,减少重复建立连接的开销。然而,不同HTML页面间无法通过此机制保持连接。此机制在提升效率的同时,也可能对高负载网站的性能产生影响。
21 2
基于Django的电子商务网站开发(连载6)
|
6天前
|
SQL 前端开发 Unix
基于Django的电子商务网站开发(连载3)
本文首先介绍了Python的安装选择,建议基于2.X系列进行维护工作,而新项目则选用3.X系列,并提供了官方下载地址及环境配置说明。随后,文章详细阐述了Django框架的特点和设计理念,包括其核心组件、快速开发原则及DRY原则,并简述了Django的工作流程和技术优势。
17 6
|
6天前
|
数据库 数据安全/隐私保护 Python
基于Django的电子商务网站开发(连载8)
本章节详细介绍了电子商务网站的实现,包括用户信息模块(注册、登录、信息展示及密码修改),商品信息模块(维护、分页显示、模糊查询及详情展示),购物车模块(商品显示、添加、删除及数量修改),送货地址模块(显示、添加、修改及删除),订单模块(显示、删除),以及订单支付模块等功能需求和实现细节。
17 4
|
XML 测试技术 数据格式
基于Django的电子商务网站开发(连载17)
基于Django的电子商务网站开发(连载17)
64 0
基于Django的电子商务网站开发(连载17)
|
XML 测试技术 数据库
基于Django的电子商务网站开发(连载34)
基于Django的电子商务网站开发(连载34)
56 0
基于Django的电子商务网站开发(连载34)
|
安全 测试技术 Python
基于Django的电子商务网站开发(连载39)
顾翔老师开发的bugreport2script开源了,希望大家多提建议。文件在https://github.com/xianggu625/bug2testscript, 主文件是:zentao.py 。bugreport是禅道,script是python3+selenium 3,按照规则在禅道上书写的bugreport可由zentao.py程序生成py测试脚本。
66 0
基于Django的电子商务网站开发(连载39)
|
XML 测试技术 数据库
基于Django的电子商务网站开发(连载24)
基于Django的电子商务网站开发(连载24)
49 0
基于Django的电子商务网站开发(连载24)
|
XML 存储 算法
基于Django的电子商务网站开发(连载25)
基于Django的电子商务网站开发(连载25)
156 0
基于Django的电子商务网站开发(连载25)
|
XML 测试技术 数据格式
基于Django的电子商务网站开发(连载33)
顾翔老师开发的bugreport2script开源了,希望大家多提建议。文件在https://github.com/xianggu625/bug2testscript, 主文件是:zentao.py 。bugreport是禅道,script是python3+selenium 3,按照规则在禅道上书写的bugreport可由zentao.py程序生成py测试脚本。
86 0
基于Django的电子商务网站开发(连载33)