cookie与session

cookie介绍

HTTP协议 是无状态的,每次请求连接都是不保存客户端状态的,cookie就是用来保存客户端状态的。试想一下,如果每次登录一个网站,每次跳转页面都不会记录我的信息,都要求重新输入密码,是不是很不爽?

Cookie具体指的是一段小信息,它是服务器发送出来存储在浏览器上的一组组键值对,下次访问服务器时浏览器会自动携带这些键值对,以便服务器提取有用信息。 简单来说,就是保存在客户端浏览器的键值对。

当你登录一个网站后,服务端会把你的用户名、密码等信息发到你的浏览器上保存起来,下次再访问请求的时候,浏览器会自动带上这些cookie,服务器就会认识。

session介绍

上述的cookie本身保存在客户端,容易被拦截,不是很安全,所以就有了session。 浏览器登录网站成功后,服务器会根据某种算法生成一个随机字符串,发给浏览器,浏览器保存在本地。服务器记录了随机字符串与用户信息的对应关系,之后浏览器 再来访问,就带着字符串就来了,然后服务器识别这个字符串比对 对应关系,如果有这个关系,就知道是你来了。

token

session虽然相对安全,数据保存在服务端,一个用户保存一份,多个用户保存多份,一旦用户量非常大,会占用服务端大量的资源,占用服务器硬盘空间。

所以就有了token,先提前规定好加密算法。当用户来的时候,比如说username,就会用加密算法对username生成一个随机字符串,然后把username+随机字符串发送给浏览器保存。当这个用户再来的时候,服务器会拿到username再去用加密算法加密,得到的随机字符串与保存在浏览器本地的字符串做比对,判断是否是合法用户。

django操作cookie

设置cookie

obj = HttpResponse()   # 利用obj对象才可以操作cookie
return obj obj.set_cookie('k1', 'v1') # 告诉浏览器设置键值对

设置cookie过期时间:

obj.set_cookie('k1','v1',max_age=3)
obj.set_cookie('k1','v1',expires=3) # expires参数 是为IE浏览器准备用的

cookie超时时间是以秒 作为单位的

一些参数:

  • key, 键
  • value='', 值
  • max_age=None, 超时时间
  • expires=None, 超时时间(IE requires expires, so set it if hasn't been already.)
  • path='/', Cookie生效的路径,/ 表示根路径,特殊的:根路径的cookie可以被任何url的页面访问
  • domain=None, Cookie生效的域名
  • secure=False, https传输
  • httponly=False 只能http协议传输,无法被JavaScript获取(不是绝对,底层抓包可以获取到也可以被覆盖

获取cookie

request.COOKIES.get('k1')   # 获取浏览器携带的cookie值

简单的测试:

from django.shortcuts import render, HttpResponse, redirect

# Create your views here.

def login(request):
if request.method == 'POST':
username = request.POST.get('username')
password = request.POST.get('password')
if username == 'cwz' and password =='123':
obj = redirect('/home/')
obj.set_cookie('whoami', 'cwz')
return obj
return render(request, 'login.html') def home(request):
if request.COOKIES.get('whoami'):
return HttpResponse('只有登录成功才能到这儿') return redirect('/login/')

删除cookie

用delete_cookie

def logout(request):
obj = redirect('/login/')
obj.delete_cookie('whoami')
return obj

基于cookie实现的登录认证

request.get_full_path()   # 获取用户输入的url
request.path_info # 获取用户输入的url
from django.shortcuts import render, HttpResponse, redirect

# Create your views here.

def login(request):
if request.method == 'POST':
username = request.POST.get('username')
password = request.POST.get('password')
if username == 'cwz' and password == '123': old_path = request.GET.get('next')
if old_path:
obj = redirect(old_path) else:
obj = redirect('/home/')
obj.set_cookie('whoami', 'cwz')
return obj
return render(request, 'login.html') from functools import wraps def auth_login(func):
@wraps(func)
def inner(request, *args, **kwargs):
res = func(request, *args, **kwargs)
if request.COOKIES.get('whoami'):
# print(request.get_full_path())
# print(request.path_info)
return res
else:
current_path = request.path_info
return redirect('/login/?next=%s' % current_path) # 没有登录的用户,跳转到登录页面 return inner @auth_login
def home(request):
if request.COOKIES.get('whoami'):
return HttpResponse('只有登录成功才能到这儿') return redirect('/login/') @auth_login
def index(request):
return HttpResponse('index页面,登录之后才能访问') @auth_login
def reg(request):
return HttpResponse('reg页面,登录之后才能访问') @auth_login
def logout(request):
obj = redirect('/login/')
obj.delete_cookie('whoami')
return obj

django操作session

django中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。
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失效策略。

注意事项:

  • 由于session是保存在服务器数据库的,所以django在操作session时要先执行数据库迁移命令, 生成django_session表

  • **django 默认的session失效时间是14天 **

设置session

request.session['k1'] = 'v1'
  • django内部自动调用算法生成一个随机字符串
  • 在django_session添加数据, 数据也是加密处理
  • 将产生的随机字符串返回给客户端,让浏览器保存, 字符串的形式为 sessionid : 随机字符串

获取session值

def get_session(request):
res = request.session.get('k1')
print(res)
return HttpResponse('获取成功')

django内部处理的事情

  • django内部会自动去请求头里面获取cookie
  • 拿到sessionid所对应的随机字符串去django_session表中比对
  • 如果比对上了,会将随机字符串对应的值取出来,放在request.session中。

删除session

request.session.delete()    # 客户端与服务端的session都会删除

request.session.flush()     # 建议使用

删除session只会根据浏览器的不同删出对应的数据

设置超时时间

request.session.set_expiry(value)
# 如果value是个整数,session会在些秒数后失效。
# 如果value是个datatime或timedelta,session就会在这个时间后失效。
# 如果value是0,用户关闭浏览器session就会失效。
# 如果value是None,session会依赖全局session失效策略。

django中session配置

Django中默认支持Session,其内部提供了5种类型的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中Session相关设置

cookies和sessions组件的更多相关文章

  1. django 中的聚合和分组 F查询 Q查询 事务cookies和sessions 066

    1 聚合和分组 聚合:对一些数据进行整理分析 进而得到结果(mysql中的聚合函数) 1aggregate(*args,**kwargs) : 通过对QuerySet进行计算 ,返回一个聚合值的字典. ...

  2. Cookies和Sessions

    Cookie和Session 为什么会有cookie和session? 由于http协议是无状态的 无法记住用户是谁,cookie主要是在浏览器上记录客户的状态,session主要是用来在服务端记录客 ...

  3. 项目前端 - vue配置 | axios配置 | cookies配置 | element-ui配置 | bootstrap配置

    vue项目创建 环境 1.傻瓜式安装node: 官网下载:https://nodejs.org/zh-cn/ ​ 2.安装cnpm: >: npm install -g cnpm --regis ...

  4. 7.vue前台配置、插件、组件

    目录 luffy前台配置 axios前后台交互 cookies操作 element-ui页面组件框架 bootstrap页面组件框架 luffy前台配置 axios前后台交互 安装:前端项目目录下的终 ...

  5. Pycharm建立web2py项目并简单连接MySQL数据库

    引言 web2py是一种免费的,开源的web开发框架,用于敏捷地开发安全的,数据库驱动的web应用:web2p采用Python语言编写,并且可以使用Python编程.web2py是一个完整的堆栈框架, ...

  6. Pycharm建立web2py项目

    web2py是一种免费的,开源的web开发框架,用于敏捷地开发安全的,数据库驱动的web应用:web2p采用Python语言编写,并且可以使用Python编程.web2py是一个完整的堆栈框架,也就是 ...

  7. Servlet 3.1学习笔记

    Servlet 3.1学习笔记 参考文档 Servlet 3.1标准 什么是 Servlet ? Servlet 是基于 Java 平台的 Web 组件,由一个容器管理,能够生成动态内容. 什么是 S ...

  8. nodejs review-03

    39 Serve different file types with our server 处理文件类型 function content_type(filename) { var ext = pat ...

  9. php 教程列表

    php教程 php概述 php环境搭建 PHP书写格式 php变量 php常量 PHP注释 php字符串 string PHP整型 integer PHP浮点型 float php布尔型 php数据类 ...

随机推荐

  1. Missing associated label more...

    1.加上placeholder,可以为空 2.放在label标签中

  2. Android utils 之 日志工具类

    工具类 在开发的过程中,我们时常会对代码执行特定的处理,而这部分处理在代码中可能多次用到,为了代码的统一性.规范性等,通过建工具类的方式统一处理.接下来我会罗列各种工具类. 日志工具类 在utils文 ...

  3. 设置tabBar的图片/高度/title颜色

    实现了一下内容: 1.设置tabBarItem选中及非选中时的图片,图片充满item; 2.调整了 tabBar 高度; 3.改变了title颜色及位置. ------------代码如下: ---T ...

  4. Word文档转为MD

    最近整理近年的一些知识笔记,需要将一些之前用word写好的文档转为markdown格式,主要的方法是先将word转换为html格式,再将html转换为markdown格式. Step1. Word t ...

  5. CentOS7 安装Python3.6.8

    CentOS7 安装Python3.6.8 1. 安装依赖环境 yum -y groupinstall "Development tools" yum -y install zli ...

  6. windows系统下压缩文件成tar.gz格式的方法

    tar.gz 是linux和unix下面比较常用的格式,几个命令就可以把文件压缩打包成tar.gz格式,然而这种格式在windows并不多见,WinRAR.WinZip等主流压缩工具可以释放解开,却不 ...

  7. IntersectionObserver API,观察元素是否进入了可视区域

    网页开发时,常常需要了解某个元素是否进入了"视口"(viewport),即用户能不能看到它. 上图的绿色方块不断滚动,顶部会提示它的可见性. 传统的实现方法是,监听到scroll事 ...

  8. java之instanceof操作符

    a intanceof A:判断a是否是类A的的一个实例,返回值为boolean public class Person extends Object{} public class Student e ...

  9. 《2019年小米春季上海 PHP 实习生招聘面试题》部分答案解析

    1 丶 Nginx 怎么实现负载均衡 这个还是比较简单 1.轮询 这种是默认的策略,把每个请求按顺序逐一分配到不同的 server,如果 server 挂掉,能自动剔除. 2.最少连接 把请求分配到连 ...

  10. Swoole编译安装步骤

    Swoole扩展是按照php标准扩展构建的.使用phpize来生成php编译配置,./configure来做编译配置检测,make进行编译,make install进行安装. 请下载releases版 ...