码迷,mamicode.com
首页 > 其他好文 > 详细

Django之Cookie

时间:2017-07-08 17:47:31      阅读:189      评论:0      收藏:0      [点我收藏+]

标签:bsp   时间   生效   https   for   signed   path   highlight   域名   

cookie是什么?

  1. 保存在浏览器端“键值对”
  2. 服务端可以向用户浏览器端写cookie
  3. 客户端每次发请求时,会携带cookie去

应用场景:

  1. 投票
  2. 用户登录

 

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获取(不是绝对,底层抓包可以获取到也可以被覆盖)

set_cookie源码:

def set_cookie(self, key, value=‘‘, max_age=None, expires=None, path=‘/‘,
			   domain=None, secure=False, httponly=False):

由于cookie保存在客户端的电脑上,所以,JavaScript和jquery也可以操作cookie。

<script src=‘/static/js/jquery.cookie.js‘></script>
$.cookie("list_pager_num", 30,{ path: ‘/‘ });
技术分享
#urls.py
    url(r^login/, views.login),
    url(r^index/, views.index),
    
#views.py
from django.shortcuts import render,redirect,HttpResponse

def login(request):

    if request.method == "GET":
        return render(request,login.html)
    else:
        user = request.POST.get("username")
        pwd = request.POST.get("password")
        print(user,pwd)
        if user == "alex" and pwd == "123":
            obj = redirect(/index/)
            obj.set_cookie(ticket,sdlfkjlakjfdlkfjdkljf)
            return obj
        else:
            return render(request,login.html)

def index(request):
    # 去请求的cookie中找凭证
    tk = request.COOKIES.get("ticket")
    if not tk:
        return redirect(/login/)
    return render(request,index.html)
    
    
#login.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<form method="POST" action="/login/">
    <input type="text" name="username">
    <input type="password" name="password">
    <input type="submit" value="提交">

</form>

</body>
</html>

#index.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<p>Welcome Pythoner!!!</p>

</body>
</html>
cookie基础使用

 

Django之Cookie

标签:bsp   时间   生效   https   for   signed   path   highlight   域名   

原文地址:http://www.cnblogs.com/luchuangao/p/7137276.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!