http://www.cnblogs.com/liwenzhou/p/8343243.html

一、Cookie

Cookie是什么?

  就是保存在客户端浏览器上的键值对。

Cookie为什么存在?

  因为HTTP请求是没有状态的,每一次请求都是独立的。

服务端控制着响应,在响应里可以让浏览器在本地保存键值对,下一次登录时可以自动携带这个值。

Cookie的应用:

  1、登陆、七天免登陆。

  2、记录用户的浏览习惯。

  3、简单的投票限制。

Cookie是服务端设置的,浏览器可以不让服务端设置Cookie(禁用),但是就无法登陆。

Cookie默认在浏览器关闭时清楚。

(1)Cookie设置流程(以登陆为例):

  1、在登陆数据提交时red = redrict(...)     red.set_cookie("key","value")

  2、在主页验证是否有cookie: request.COOKIES.get("...")

(2)装饰器

由于在每个页面都会用到Cookie,所以可以把验证Cookie的语句封装成装饰器来使用:

(3)验证cookie后返回之前的页面  path_info

(4)cookie的保存时间max_age

(5)删除cookie

 def cookie_decoration(func):
     def inner(request):
         ":
             return func(request)
         else:
             present_url = request.path_info    #获取当前url地址
             return redirect("/login"+"/?pre="+present_url)
     return inner

 def login(request):
     if request.method == "POST":
         ":
             if request.GET.get("pre"):  #获取上一页url地址
                 red = redirect(request.GET.get("pre"))
             else:
                 red = redirect("/home")
             red.set_cookie(",max_age=30)  #max_age是cookie值保存的时间,以秒为单位
             return red
         else:
             return HttpResponse("error")
     return render(request,"login.html",locals())

 @cookie_decoration
 def home(request):
     return render(request,"home.html",locals())

 def logout(request):
     red = redirect("/login")
     red.delete_cookie("is_login")
     return red

二、session

为什么有session?

  cookie有一些弊端,其存储的数据是有限制的,而且数据存储在客户端,容易被窃取,所以出现session,session没有数据大小限制,且数据存储在服务端,安全性强。

  session依赖于cookie,他把随机字符串作为一个大字典的键,把数据都存储在这个大字典中,字典存储在服务端,而把这个随机字符串作为cookie的值传给客户端,所以客户端只拿到这个随机值,通过这个值去服务端取数据。

注意:session需要创建数据库信息,才能把键值对存储在数据库中,不然无法使用,记得makemigrations

 def cookie_decoration(func):
     def inner(request):
         if request.session.get("is_login") == "true":
             return func(request)
         else:
             present_url = request.path_info    #获取当前url地址
             return redirect("/app02/login"+"/?pre="+present_url)
     return inner

 def login(request):
     if request.method == "POST":
         ":
             request.session['is_login'] = "true"
             if request.GET.get("pre"):  #获取上一页url地址
                 return redirect(request.GET.get("pre"))
             else:
                 return redirect("/app02/home")

         else:
             return HttpResponse("error")
     return render(request,"login.html",locals())

 @cookie_decoration
 def home(request):
     return render(request,"home.html",locals())

 def logout(request):
     request.session.flush()
     return redirect("/app02/login")

Django之Cookie和Session的更多相关文章

  1. Django之Cookie、Session、CSRF、Admin

    Django之Cookie.Session.CSRF.Admin   Cookie 1.获取Cookie: 1 2 3 4 5 6 request.COOKIES['key'] request.get ...

  2. [py][mx]django的cookie和session操作-7天免登录

    浏览器同源策略(same-origin policy) csrf攻击防御核心点总结 django的cookie和session操作-7天免登录 flask操作cookie&django的see ...

  3. Django基础cookie和session

    Django基础cookie和session 1.会话跟踪 ​ 什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应.例如给10086打个电话,你就是客户端, ...

  4. django的cookie和session以及内置信号、缓存

    cookie和session cookie和session的作用: cookie和session都记录了客户端的某种状态,用来跟踪用户访问网站的整个回话.两者最大的区别是cookie的信息是存放在浏览 ...

  5. django的cookie 和session

    Cookie 1.获取cookie: request.COOKIES['key'] request.get_signed_cookie(key, default=RAISE_ERROR, salt=' ...

  6. Django组件-cookie与session

    一.会话跟踪技术 1.什么是会话跟踪技术 我们需要先了解一下什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应.例如你给10086打个电话,你就是客户端,而 ...

  7. web框架开发-Django组件cookie与session

    http协议的每一次都是无保存状态的请求,这会带来很多的不方便,比如,一刷新网页,或者进入该网页的其他页面,无法保存之前的登录状态.为了解决类似这样的问题,引入了会话跟踪 会话跟踪技术 1 什么是会话 ...

  8. Django 之 cookie和session

    一. Cookie 1.Cookie的由来 因为HTTP协议是无状态的,无状态的意思就是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,也不会受前后请求响应情况直接影响.简 ...

  9. django之COOKIE 与 SESSION

    COOKIE 与 SESSION 概念 cookie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又需要“保持状态”,因此cookie就是在这样一个场景下诞生. cookie ...

  10. 9.Django组件-cookie和session

    HTTP协议的无保存状态,对两次请求没有任何关联.每次请求都是相互独立的. 1.cookie简介 什么是会话跟踪技术我们需要先了解一下什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会 ...

随机推荐

  1. MATLAB accumarray

    先看看subs和val的具体内容 subs = [1 1 1; 2 1 2; 2 3 2; 2 1 2; 2 3 2]; subs = 1     1     1 2     1     2 2    ...

  2. android 图片上传图片 报Socket: Broken pipe

    上传图片的时候报如下错误: 上传失败的原因是服务器限制了文件上传的大小.让服务端改一下配置文件就好了

  3. C++ 中 auto 与 decltype 的用法与区别

    最近在恶补 C++ 知识的时候,学习到了一些 C++11 标准的新特性,利用这些新特性,我们能够更快地提高编程效率,从而实现我们的目标,在此特意记下学习过程中所学习到的一些东西,方便日后的回顾和复习. ...

  4. Neutron local network 学习

    local network 的特点是不会与宿主机的任何物理网卡相连,也不关联任何的 VLAN ID.   对于每个 local netwrok,ML2 linux-bridge 会创建一个 bridg ...

  5. Binary Search(Java)(非递归)

    public static int rank(int[] array, int k) { int front = 0, rear = array.length - 1; while(front < ...

  6. C#直接使用DllImport调用C/C++动态库(dll文件)

    1.C/C++动态库的编写 下面是我编写的一个比较简单的C++dll文件用来测试,关于如何编写dll文件,我这里便不再赘述,不懂得自行查询, (1).h文件 #ifdef MYDLL_EXPORTS ...

  7. java的List列表转成Tree(树形)结构列表

    直接看借鉴博客:https://blog.csdn.net/massivestars/article/details/53911620/ 由于我的业务没有父子级id两个字段,只有一个层级id字段来分层 ...

  8. CodeForces 91B Queue

    题目链接:http://codeforces.com/contest/91/problem/B 题目大意: 有n头大象排队买票,第i头大象的年龄为ai,如果有比他年轻的大象排在他前面,这头大象就会非常 ...

  9. Windows Linux的cmd命令查询指定端口占用的进程并关闭

    以端口8080为例: Windows  1.查找对应的端口占用的进程:netstat  -aon|findstr  "8080",找到占用8080端口对应的程序的PID号: 2.根 ...

  10. 洛谷P1220关路灯题解

    题目 此题是一个状态转移方程还算比较多的一个区间DP,这个题也能启示我们如果某个状态不能够很好地解决问题,那么不妨试试再加一维,而且如果转移顺序不确定的话,可以试试记忆化搜索,说不定就可以比较容易的写 ...