Django Cookie于Session
一.Cookie与Session由来
因为Http协议的特性,每一次来自用户浏览器的请求都是无状态且独立的,通俗地说,就是无法保存用户状态,后台服务器根本就不知道当前请求和以前及以后请求是否来自同一用户,对于静态网站,这可能不是一个问题,但是对于动态网站来说,无法识别用户并保存用户状态是致命的,根本就无法提供服务。
为了保持链接状态,网站会通过用户的浏览器在用户机器内被限定的硬盘位置中写入一些数据,也就是所谓的Cookie.通过Cookie可以保存一些诸如用户名、浏览记录、表单记录等各种数据。但是这种方式非常不安全,因为Cookie保存在用户的机器上,如果Cookie被伪造、篡改或删除,就会造成极大的安全威胁,因此,当下网站设计通常将Cookie用来保存一些不重要的内容,实际的用户数据和状态还是以Session会话的方式保存在服务器。
Session就是在服务器端的Cookie,将用户数据保存在服务端,远比保存在用户端要安全方便和快捷得多。Session是依赖于Cookie的,但与Cookie的不同之处就是Session将所有的数据都放在服务端,用户浏览器的Cookie中只会保存一个非明文的识别信息。
Session是大多数网站都需要具备的功能。Django为我们提供了一个通用的Session框架,并且可以使用多种session数据的保存方式,通常情况,没有特别需求的话,都会使用保存在数据库内的方式.
Django的session框架支持匿名会话,封装了cookie的发送和接收过程,cookie包含一个会话ID而不是数据本身.Django的会话框架完全地唯一地基于Cookie。
二.Cookie的使用
1.cookie原理
其实Cookie是key-value结构,类似一个python中的字典,随着服务端的响应发送给客户端浏览器,然后客户端浏览器会把Cookie保存起来,当下一次再访问服务器把Cookie再发送给服务端。
工作原理:由服务器产生内容,浏览器收到请求后保存在本地;当浏览器再次访问时,浏览器会自动带上Cookie,这样服务器就能通过Cookie的内容来判断.
2.Cookie规范
1.Cookie大小上限为4KB
2.一个服务器最多再客户端浏览器上保存20个Cookie
3.一个浏览器最多保存300个Cookie
这些数据知识HTTP的Cookie规范,在浏览器发展迅速的今天,一些浏览器可能对Cookie规范扩展了一些。
3.Django中操作Cookie
设置Cookie
rep = HttpResponse(...)
rep = render(request,...)
rep.set_cookie(key,value,...)
rep.set_signed_cookie(key,value,salt='',...)
参数:
1.key,键
2.value,值
3.max_age=None超时时间,Cookie需要延续的时间(以秒为单位),如果参数时\None,这个Cookie会延续到浏览器关闭为止
4.expires=None,超时时间,传一个datatime对象
5.path='/',Cookie生效的路径,/表示根路径,设置path='/index/',那么只有访问index的时候,才会携带cookie
6.domin=None,Cookie生效的域名.
7.secure=False,浏览器将通过HTTPS来回传Cookie
8.httponly=False,只能HTTP协议传输,无法被JavaScript获取
获取Cookie
request.COOKIES('key')
request.get_signed_cookie(key,default=RAISE_ERROR,salt='',max_age=None)
参数:
1.default:默认值
2.salt:加密盐
3.max_age:后台控制过期时间
删除Cookie
rep = HttpResponse('abc')
rep.delete_cookie('user')
三.Session的使用
session工作流程
1.生成随机字符串
2.存储数据库
3.写入cookie
注意:session必须跟cookie连用
Session操作
# 获取、设置、删除Session中数据
request.session['k1']
request.session.get('k1',None)
request.session['k1'] = 123
request.session.setdefault('k1',123) # 存在则不设置
del request.session['k1']
# 所有 键、值、键值对
request.session.keys()
request.session.values()
request.session.items()
request.session.iterkeys()
request.session.itervalues()
request.session.iteritems()
# 会话session的key
request.session.session_key
# 将所有Session失效日期小于当前日期的数据删除
request.session.clear_expired()
# 检查会话session的key在数据库中是否存在
request.session.exists("session_key")
# 删除当前会话的所有Session数据(只删数据库)
request.session.delete()
  
# 删除当前的会话数据并删除会话的Cookie(数据库和cookie都删)。
request.session.flush()
    这用于确保前面的会话数据不可以再次被用户的浏览器访问
    例如,django.contrib.auth.logout() 函数中就会调用它。
# 设置会话Session和Cookie的超时时间
request.session.set_expiry(value)
    * 如果value是个整数,session会在对应秒数后失效。
    * 如果value是个datatime或timedelta,session就会在这个时间后失效。
    * 如果value是0,用户关闭浏览器session就会失效。
    * 如果value是None,session会依赖全局session失效策略。
四.Django中Session配置
1. 数据库Session
SESSION_ENGINE = 'django.contrib.sessions.backends.db'   # 引擎(默认)
2. 缓存Session
SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # 引擎
SESSION_CACHE_ALIAS = 'default'                            # 使用的缓存别名(默认内存缓存,也可以是memcache),此处别名依赖缓存的设置
3. 文件Session
SESSION_ENGINE = 'django.contrib.sessions.backends.file'    # 引擎
SESSION_FILE_PATH = None                                    # 缓存文件路径,如果为None,则使用tempfile模块获取一个临时地址tempfile.gettempdir() 
4. 缓存+数据库
SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db'        # 引擎
5. 加密Cookie Session
SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies'   # 引擎
其他公用设置项:
SESSION_COOKIE_NAME = "sessionid"        # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串(默认)
SESSION_COOKIE_PATH = "/"                # Session的cookie保存的路径(默认)
SESSION_COOKIE_DOMAIN = None              # Session的cookie保存的域名(默认)
SESSION_COOKIE_SECURE = False             # 是否Https传输cookie(默认)
SESSION_COOKIE_HTTPONLY = True            # 是否Session的cookie只支持http传输(默认)
SESSION_COOKIE_AGE = 1209600              # Session的cookie失效日期(2周)(默认)
SESSION_EXPIRE_AT_BROWSER_CLOSE = False   # 是否关闭浏览器使得Session过期(默认)
SESSION_SAVE_EVERY_REQUEST = False        # 是否每次请求都保存Session,默认修改之后才保存(默认)
												
											Django Cookie于Session的更多相关文章
- Python Web框架篇:Django cookie和session
		
part 1 概念 在Django里面,cookie和session都记录了客户端的某种状态,用来跟踪用户访问网站的整个回话. 两者最大的区别是cookie的信息是存放在浏览器客户端的,而sessio ...
 - python Django cookie和session
		
在一个会话的多个请求中共享数据,这就是会话跟踪技术.例如在一个会话中的请求如下: 请求银行主页: 请求登录(请求参数是用户名和密码): 请求转账(请求参数与转账相关的数据): 请求信誉卡还款(请求参 ...
 - falsk 与 django cookie和session存、取、删的区别
		
falsk cookie的存取删需导入from flask import Flask,make_response,request# 存COOKIE的方法@app.route('/setcookie') ...
 - django cookie与session组件
		
本文目录 1 会话跟踪技术 2 cookie介绍 Django中操作Cookie Session Django中Session相关方法 Django中的Session配置 CBV中加装饰器 回到目录 ...
 - Django - Cookie、Session、自定义分页和Django分页器
		
2. 今日内容 https://www.cnblogs.com/liwenzhou/p/8343243.html 1. Cookie和Session 1. Cookie 服务端: 1. 生成字符串 2 ...
 - django cookie and session
		
cookie和session 1.cookie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又需要“保持状态”,因此cookie就是在这样一个场景下诞生. cookie的工作 ...
 - django cookie、session
		
Cookie.Session简介: Cookie.Session是一种会话跟踪技术,因为http请求都是无协议的,无法记录上一次请求的状态,所以需要cookie来完成会话跟踪,Seesion的底层是由 ...
 - Django—Cookie and Session
		
一.Cookie Cookie,有时也用其复数形式 Cookies,指某些网站为了辨别用户身份.进行 session 跟踪而储存在用户本地终端上的数据(通常经过加密). 1. 应用 服务器可以利用Co ...
 - Django cookie与session
		
cookie与session关系 cookie 是保存在客户端浏览器的键值对,浏览器发送请求时候会自动携带. session 1.生成随机字符串 2.回给浏览器,让它写到cookie # {" ...
 
随机推荐
- [译文]casperjs的API-clientutils模块
			
casper提供了少量的客户端接口用来进行远程DOM环境注入,通过clientutils模块的ClientUtils类实例中的__utils__对象来执行: casper.evaluate(funct ...
 - Python3之collections模块
			
简介 collections是Python内建的一个集合模块,提供了许多有用的集合类. namedtuple namedtuple 是一个函数,它用来创建一个自定义的元组对象,并且规定了元组元素的个数 ...
 - mysql查询语句常用字段操作函数
			
一.concat()函数 1.功能:将多个字符串连接成一个字符串. 2.语法:concat(str1, str2,...) 返回结果为连接参数产生的字符串,如果有任何一个参数为null,则返回值为nu ...
 - 百度地图 Infowidow 内容(content 下标签) 点击事件
			
需要监听 infowindow 的打开事件 ,查看InfoWindow API 实现 html 点击效果 代码 var infoWindow = that.createDangerInfoWindo ...
 - PHP会话cookie类的封装
			
<?php header('content-type:text/html;charset=utf-8');/** * 完成cookie的设置.删除.更新.读取 */class Cookie{ ...
 - Numpy中扁平化函数ravel()和flatten()的区别
			
在Numpy中经常使用到的操作由扁平化操作,Numpy提供了两个函数进行此操作,他们的功能相同,但在内存上有很大的不同. 先来看这两个函数的使用: from numpy import * a = ar ...
 - APP元素的四大类
			
一个完整的APP包括四大类:各种“栏”.内容视图.控制元素.临时视图 各种“栏”:状态栏.导航栏.标签栏.工具栏.范围栏 内容视图:列表视图.卡片式图.集合视图.图片视图.文本视图 控制元素:用于控制 ...
 - C: City----逆向并查集
			
C: City 时间限制: 1 s 内存限制: 128 MB 题目描述 如果城市A和城市B互通,城市B和城市C互通,那么城市A和城市C也互通,A.B.C三个城市算一个聚集点.先 ...
 - redis的主从同步
			
一.redis的主从操作流程 1. 准备三个redis配置文件 #进入redis的配置文件夹,准备好这几个文件,6379不用管,默认的,和这次操作无关 [root@qishi ~]# cd /etc/ ...
 - Apache 配置代理服务
			
1.根据项目需要,Apache服务下面有2个tomcat 分别指向不同的域名 2.修改 Apache-conf-httpd.conf LoadModule proxy_module modules/m ...