Django之Cookie

摘要:
$cookie;#urls.pyurl,url,#views.pyfromdjango.shortcutsimportrender,redirect,HttpResponsedeflogin:irfequest.method==“GET”:returnrenderelse:user=request.POST.getpwd=request.POST.getprintifuser==“alex”andpwd=“123”:obj=redirectobj.set _ Cookie returnobjelse:returnrenndendex:#转到请求的Cookie查找凭证tk=request。饼干。getifnottk:returnredirectreturnrender#登录。html˂!

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。

Django之Cookie第1张

<script src='http://t.zoukankan.com/static/js/jquery.cookie.js'></script>
$.cookie("list_pager_num", 30,{ path: '/' });
Django之Cookie第2张Django之Cookie第3张
#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基础使用
max_age和expires的区别:
max_age=None, 超时时间【推荐】
# obj.set_cookie('ticket','sdlfkjlak',max_age=10)

expires=None, 超时时间(需要调用datetime模板进行设置)
#import datetime
#from datetime import timedelta
#ct = datetime.datetime.utcnow()
#v = timedelta(seconds=10)
#value = ct + v
#obj.set_cookie('ticket','sdlfkjlak',expires=value)
Django之Cookie第4张Django之Cookie第5张
#urls.py
    url(r'^li1/', views.li1),
    url(r'^li2/', views.li2),

#views.py
"path的使用"
def li1(request):
    print(request.COOKIES)
    obj = HttpResponse('OK')
    obj.set_cookie('k2','v2',path='/li1')
    return obj

def li2(request):
    print(request.COOKIES)
    obj = HttpResponse('OK')
    return obj

#只有li1能获取k2
cookie设置path

签名:

  • cookie签名
  • 自定义签名
Django之Cookie第6张Django之Cookie第7张
#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/')
            import datetime
            from datetime import timedelta
            ct = datetime.datetime.utcnow()
            v = timedelta(seconds=10)
            value = ct + v
            # obj.set_cookie('ticket','sdlfkjlak',max_age=10)
            obj.set_signed_cookie('ticket','123123',salt='ppppppp')
            # obj.set_cookie('ticket','sdlfkjlak',expires=value)
            return obj
        else:
            return render(request,'login.html')

def index(request):
    # 去请求的cookie中找凭证
    tk = request.get_signed_cookie("ticket",salt='ppppppp')
    print(tk)
    if not tk:
        return redirect('/login/')
    return render(request,'index.html')
    

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

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

</body>
</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>
cookie签名实例
Django之Cookie第8张Django之Cookie第9张
#settings.py

#SIGNING_BACKEND就相当于TimestampSigner
SIGNING_BACKEND ="c1.MySigner"

#c1.py
from django.core.signing import TimestampSigner

class MySigner(TimestampSigner):
    #加签名
    def sign(self, value):
        return value+'123123123'

    #去签名
    def unsign(self, value, max_age=None):
        v = value[0:-8]
        return v
自定义签名

免责声明:文章转载自《Django之Cookie》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇页面不加载CSS解决办法Linux服务器性能检测命令集锦下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

《图解 HTTP》 摘要一

学习过程对书本的内容的摘要以及总结,逐步完善,带有个人理解成分。 Web 及网络基础 使用 HTTP 协议访问 Web 客户端:通过获取请求获取服务资源的 Web 浏览器等 HTTP 全称:HtyperText Transfer Protocol WWW 全称:Wrold Wide Web SGML 标准通用标记语言 全称:Standard Gener...

arale-cookie 使用

https://www.npmjs.com/package/arale-cookiearale-cookie 使用 define(function() { var Cookie = require('cookie'); Cookie.set('foo', 3); Cookie.set('bar', 4, {...

loadrunner---&amp;lt;二&amp;gt;---菜鸟对cookie的思考

http://www.cnblogs.com/Pierre-de-Ronsard/archive/2012/11/19/2772630.html loadrunner---<二>---菜鸟对cookie的思考 lr是怎么将cookie添加到录制的脚本中的?lr中cookie是做什么的? 首先将解决两个疑问: 1--什么是cookie?-- C...

微信--高效解决token及授权用户openid的持久化处理办法

摘要        关于微信开发的话题,例子确实已经有不少,但大部分都是人云亦云,很多小细节或者需要注意的地方却大多没有讲清楚,这令很多刚开始开发的人感觉大很迷茫。而我今天要说的话题,主要着眼于两个方面。 一:如何存储获取用户信息及调用第三方接口所需要的token. 二 : 第三方页面授权,如何减少从微信服务器获取用户openid的次数以及减少获取用户信...

转:jmeter性能测试---登录百度进行搜索

在做web程序性能测试时,loadrunner和jmeter是两款常用的工具,两者比较起来,jmeter非常轻巧,且开源免费,上手快。这里简单介绍下jmeter的使用,以登录百度进行搜索为例。 jmeter运行需要jdk环境,这个不多做介绍。软件界面: 右击“测试计划”,添加一个线程组 线程组界面可以配置线程的数量,“Ramp-Up Period(i...

Vscode + Python + Django开发环境常见问题

Vscode 越来越好用了,轻量还跨平台。 1, 主程序安装。 2. 汉化:左侧工具条的扩展菜单,搜索 chinese 第一个就是汉化包 ,安装后重启。 3. 安装Python扩展:还是扩展菜单,搜索python 一般第一个就是, 注释为:Linting,Debugging (multi-threaded, ..... 4. 我用过Kite 自动补全,还不...