[TOC=1,5] >[success] # Cookies Cookie是由服务器端生成,发送给浏览器,浏览器将发送的cookie记录,当用户访问的时候讲cookie发送给服务器端,进行判断,一般应用场景在网页登陆。 有时候我们发现,我在谷歌浏览器登陆,但打开ie又给重新登陆,但是在使用谷歌却不用,因为cookie是储存在各自的浏览器中 ![](https://box.kancloud.cn/1c23e4ef0432e0de9e2aa5a8228b98ac_1212x77.png) >[info] ## 常用的cookies方法 >[danger] ##### 使用思路 ~~~ 1.在登录页面的时候,当用户民密码输入正确后,通过cookies 给浏览器保存cookie 的地方赋值 2.在非登录页面,判断当前cookies 是否正确并且存在 ~~~ >[danger] ##### views -set_cookie 生成cookies键值对给浏览器 ~~~ red = redirect('/index/') red.set_cookie("username",u) return red ~~~ >[danger] ##### views -set_cookie("username",u,salt='加盐') ~~~ red = redirect('/index/') red.set_signed_cookie("username",u,salt="pwd") return red ~~~ >[danger] ##### 设置时间以秒为单位-set_cookie("username",u,max_age=data) ~~~ red = redirect('/index/') #设置十秒后过期 red.set_cookie("username",u,max_age=10) return red ~~~ >[danger] ##### 以具体的时间时set_cookie("username",u,expires=data) ~~~ import datetime data = datetime.datetime.utcnow() data = data + datetime.timedelta(seconds=5) red = redirect('/index/') red.set_cookie("username",u,expires=data) return red ~~~ >[danger] ##### 设置生效路径set_cookie("username",u,path='/') >[danger] ##### 设置生效域名set_cookie("username",u,domain=None) >[danger] ##### https传输cookieset_cookie("username",u,secure=False) >[danger] ##### 只能http协议传输, >无法被JavaScript获取(不是绝对,底层抓包可以获取到也可以被覆盖)set_cookie("username",u,httponly=False) >[success] # 案例 >[danger] ##### views 登陆案例 ~~~ from django.shortcuts import render,redirect from . import models # Create your views here. def login(request): msg ="" if request.method == "GET": return render(request,'login.html',{"msg":msg}) elif request.method == "POST": u = request.POST.get('user',None) p = request.POST.get('pwd',None) if u and p : obj = models.userinfo.objects.filter(user=u, pwd=p) if obj: red = redirect("https://www.baidu.com") # 做cookies 保存 red.set_signed_cookie("username",u,salt="pwd") return red msg = "密码错误" return render(request,'login.html',{"msg":msg}) def index(request): if request.method == "GET": # 获取浏览器中的cookies u = request.COOKIES.get("username") if u : return render(request,"index.html",{'u':u}) return redirect("/login.html") ~~~ >[danger] ##### 分页案例 juqery.cookie.js和jquery-1.12.4.js,主要用这两个包版本无要求 * 思路如下: ~~~ 1.通过js 获取页面下拉选择的页数,通过$.cookie("key","val")方法进行保存。 2.前端触发页面刷新,后台通过request.COOKIE.get()方法用来接受,前端传回的值 3.通过传回的cookie,接受后改变接片值 ~~~ ~~~ <select id="ps" onchange="chan(this)"> <option value="10">10</option> <option value="20">20</option> <option value="30">30</option> <option value="40">40</option> </select> <script> $(function () { var v=$.cookie("page_count"); if(v){ $('#ps').val(v); }else { $('#ps').val(10); }; }); function chan(ths) { var v = $(ths).val(); $.cookie("page_count",v); location.reload(); } </script> ~~~ ![](https://box.kancloud.cn/01c00bd2436b8a09471f9407626cf785_678x411.png)