django_cookie

2018-01-28  本文已影响26人  两点半的杂货铺

一、什么是cookie

Cookie是由服务器端生成,发送给浏览器,浏览器将发送的cookie记录,当用户访问的时候讲cookie发送给服务器端,进行判断,一般应用场景在网页登陆。
有时候我们发现,我在谷歌浏览器登陆,但打开ie又给重新登陆,但是在使用谷歌却不用,因为cookie是储存在各自的浏览器中,所以一般应对本职工作测试的时候,我都会双开浏览器。


浏览器查看cookies.png

二、django 中cookie 方法

从浏览器获取cookie

从服务端生成cookie

red = redirect('/index/')
red.set_cookie("username",u)
return red
red = redirect('/index/')
red.set_signed_cookie("username",u,salt="pwd")
return red
red = redirect('/index/')
#设置十秒后过期
red.set_cookie("username",u,max_age=10)
return red
import datetime
data = datetime.datetime.utcnow()
data = data + datetime.timedelta(seconds=5)
red = redirect('/index/')
red.set_cookie("username",u,expires=data)
return red

三、简单登陆例子

def login(request):
    msg = ''
    if request.method == "GET":
        return  render(request,"login.html",{'msg':msg})
    elif request.method == "POST":
        u = request.POST.get('user')
        p = request.POST.get('pwd')
        if u and p :
            obj = models.user_info.objects.filter(user_name=u,user_pwd=p).first()
            if obj:
                red = redirect('/index/')
                red.set_signed_cookie("username",u,salt="pwd")
                return red
            else:
                msg = "密码错误"
                return render(request,"login.html",{'msg':msg})
        else:
            return render(request, "login.html", {'msg': msg})

def index(request):
    u = request.COOKIES.get("username")
    if u:
        return render(request,"index.html",{'u':u})
    return  redirect('/login/')

四、cookie分页的例

首先用到几个知识点

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>

后台操作变动的地方


image.png
上一篇 下一篇

猜你喜欢

热点阅读