django学习笔记---cookie

知识点

1、获取Cookie:

request.COOKIES['key']
request.get_signed_cookie(key, default=RAISE_ERROR, salt='', max_age=None)
    参数:
        default: 默认值
           salt: 加密盐
        max_age: 后台控制过期时间

2、设置Cookie:

rep = HttpResponse(...) 或 rep = render(request, ...)
 
rep.set_cookie(key,value,...)
rep.set_signed_cookie(key,value,salt='加密盐',...)
    参数:
        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保存在客户端的电脑上,所以,JavaScript和jquery也可以操作cookie。

<script src='/static/js/jquery.cookie.js'></script>
$.cookie("list_pager_num", 30,{ path: '/' });

应用实例

view.py

import datetime
def login(request):
    if request.method == "GET":
        return render(request,'login.html')
    if request.method == "POST":
        user = request.POST.get('user')
        pwd = request.POST.get('pwd')
        if user in user_data:
           if user_data[user]['pwd'] == pwd:
                res = redirect('/app2/houtai/')
                # 经过3秒后cookie失效
                # res.set_cookie('username',user,max_age=300)
                # 设置加盐
                res.set_signed_cookie('username',user,max_age=3,salt='user')

                # 设置时间节点,经过2秒后刷新url就可以跳转,要用utc时间
                # cur_time = datetime.datetime.utcnow()
                # cur_time = cur_time + datetime.timedelta(seconds=2)
                # res.set_cookie('username',user,expires=cur_time)
                # res.set_cookie('username',user)

                # 只能http协议传输,无法被JavaScript(document.cookie)获取(不是绝对,底层抓包可以获取到也可以被覆盖)
                res.set_cookie('usertype', 'John', httponly=True)
                return res
           else:
               return render(request,'login.html')
        else :
            return render(request,'login.html')

def houtai(request):
    # u = request.COOKIES.get('username')
    # 获取加盐
    u = request.get_signed_cookie('username',salt='user',default=None)
    print(u)
    # 如果关闭浏览器,重新打开,u为None
    if not u:
        return redirect('/app2/login/')
    return render(request,'houtai.html',{'user':u})

login.html

<body>
    <form action="/app2/login/" method="POST">
        <input type="text" placeholder="username" name="user"/>
        <input type="password" placeholder="password" name="pwd"/>
        <input type="submit" value="提交"/>
    </form>
    </script>
</body>

houtai.html

<body>
    <h2>欢迎用户登录: {{ user }}</h2>
</body>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值