首页 > 其他 > 详细

django的Cookie

时间:2020-07-19 18:48:11      阅读:93      评论:0      收藏:0      [点我收藏+]

 

初识cookie的设置和获取 示例

from django.shortcuts import render, redirect
from django.shortcuts import HttpResponse
from django.views import View

from app02 import models
from django.utils.safestring import mark_safe
# Create your views here.

user = {
    username: zmd,
    password: 123
}
class Login(View):
    def get(self,request):
        return render(request,app02_cookie_login.html)

    def post(self,request):
        u = request.POST.get(username)
        p = request.POST.get(pwd)
        if u != user.get(username):
            return render(request,app02_cookie_login.html)
        if p == user.get(password):
            res = redirect(/database_study/index/)
            res.set_cookie(username,u)
            return  (res)
        else:
            return render(request,app02_cookie_login.html)
class Index(View):
    def get(self,request):
        current_user = request.COOKIES.get(username)
        if not current_user:
            return redirect(/database_study/login/)
        else:
            return render(request,app02_cookie_index.html,  {current_user:current_user})

设置Cookie

  1、将要返回给客户端的内容自定义变量---使用 render或redirect 或HttpResponse

response = redirect(/database_study/index/)
response = render(request,app02_cookie_index.html)
response = HttpResponse(xxxxx)

  2、自定义变量.set_cookie(‘cookie_key‘,‘value‘)

response.set_cookie(username,u)

   可以设置的内容有

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 hasnt been already.)
        path=/,         Cookie生效的路径,/ 表示根路径,特殊的:跟路径的cookie可以被任何url的页面访问
        domain=None,      Cookie生效的域名
        secure=False,     https传输
        httponly=False    只能http协议传输,无法被JavaScript获取(不是绝对,底层抓包可以获取到也可以被覆盖)
  expires超时时间设置:
import datetime
current_time = datetime.datetime.now()
expire_time = current_time + datetime.timedelta(seconds=5)
print(current_time)
print(expire_time)
response.set_cookie(username, u, expires=expire_time)

 

 

  

 

django的Cookie

原文:https://www.cnblogs.com/zhangmingda/p/13340551.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!