Django入门到放弃之cookies
1 2 3 4 5 6 7 | request.COOKIES request.COOKIES[ 'key' ] # 获取带签名的cookie request.get_signed_cookie(key, default = RAISE_ERROR, salt = '', max_age = None ) #获取signed类型cookies default: 默认值 salt: 加密盐 max_age: 后台控制过期时间 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | rep = HttpResponse(...) rep = render(request, ...) rep.set_cookie(key,value,...) # 带签名的cookie rep.set_signed_cookie(key,value,salt = '加密盐' , max_age = None , ...) return rep 参数: 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获取(不是绝对,底层抓包可以获取到也可以被覆盖) |
1 2 3 4 | def logout(request): rep = redirect( "/login/" ) rep.delete_cookie( "user" ) # 删除用户浏览器上之前设置的usercookie值,实质是将浏览器的cookies清空 return rep |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | # 0 会话跟踪,会话保持 # 1 cookie规范 - 记住:当前网站在浏览器上cookie个数和大小有限制 - Cookie大小上限为 4KB ; - 一个服务器最多在客户端浏览器上保存 20 个Cookie; - 一个浏览器最多保存 300 个Cookie; # 2 django中操作cookie - 增:obj.set_cookie( 'key' , 'value' ) - 删: obj.delete_cookie( 'key' ) # 设置过期 - 查: request.COOKIES.get( 'key' ) - 改: obj.set_cookie( 'key' , 'value1' ) # 3 带签名的cookie(加盐,加密) - 增:obj.set_signed_cookie( 'name' , 'lqz' , '123' ) - 删: obj.delete_cookie( 'name' ) # 设置过期 - 查: request.get_signed_cookie( 'name' ,salt = '123' ) - 改: obj.set_signed_cookie( 'name' , 'lqz' , '123' ) |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | def login_auth(func): def inner(request, * args, * * kwargs): is_login = request.COOKIES.get( 'is_login' ) print (is_login) if is_login = = 'True' : res = func(request, * args, * * kwargs) print ( '##############################' ) return res else : return redirect( 'login' ) return inner @login_auth def index(request): return render(request, 'cookies/index.html' ) @login_auth def home(request): return render(request, 'cookies/home.html' ) def login(request): if request.method = = 'GET' : return render(request, 'cookies/login.html' ) else : username = request.POST.get( 'username' ) password = request.POST.get( 'password' ) if username = = 'bge' and password = = '666' : path = request.GET.get( 'returnurl' ) if path: ret = redirect(path}) else ret = redirect( 'index' ) ret.set_cookie( 'is_login' , True ) return ret else : return HttpResponse( '登录失败' ) |
"一劳永逸" 的话,有是有的,而 "一劳永逸" 的事却极少
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具
2020-08-27 Linux 五种IO模型