Django入门到放弃之cookies
2022/8/27 23:52:45
本文主要是介绍Django入门到放弃之cookies,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1.获取Cookie
request.COOKIES request.COOKIES['key'] # 获取带签名的cookie request.get_signed_cookie(key, default=RAISE_ERROR, salt='', max_age=None) #获取signed类型cookies default: 默认值 salt: 加密盐 max_age: 后台控制过期时间
2.设置Cookie
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获取(不是绝对,底层抓包可以获取到也可以被覆盖)
3.删除Cookie
def logout(request): rep = redirect("/login/") rep.delete_cookie("user") # 删除用户浏览器上之前设置的usercookie值,实质是将浏览器的cookies清空 return rep
4.django中cookie的使用
# 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')
5.登录认证示例:
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('登录失败')
这篇关于Django入门到放弃之cookies的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-24MongoDB资料:新手入门完全指南
- 2024-12-20go-zero 框架的 RPC 服务 启动start和停止 底层是怎么实现的?-icode9专业技术文章分享
- 2024-12-19Go-Zero 框架的 RPC 服务启动和停止的基本机制和过程是怎么实现的?-icode9专业技术文章分享
- 2024-12-18怎么在golang中使用gRPC测试mock数据?-icode9专业技术文章分享
- 2024-12-15掌握PageRank算法核心!你离Google优化高手只差一步!
- 2024-12-15GORM 中的标签 gorm:"index"是什么?-icode9专业技术文章分享
- 2024-12-11怎么在 Go 语言中获取 Open vSwitch (OVS) 的桥接信息(Bridge)?-icode9专业技术文章分享
- 2024-12-11怎么用Go 语言的库来与 Open vSwitch 进行交互?-icode9专业技术文章分享
- 2024-12-11怎么在 go-zero 项目中发送阿里云短信?-icode9专业技术文章分享
- 2024-12-11怎么使用阿里云 Go SDK (alibaba-cloud-sdk-go) 发送短信?-icode9专业技术文章分享