Django项目开发中cookies和session的常用操作分析
本文实例讲述了Django项目开发中cookies和session的常用操作。分享给大家供大家参考,具体如下:
COOKIES操作
检查cookies是否存在:
request.COOKIES.has_key('')
获取cookies:
request.COOKIES.get('visits','1')
if'last_visit'inrequest.COOKIES:
request.COOKIES['last_visit']
设置cookies:
response.set_cookie('',value)
SESSION操作
获取session:
fav_color=request.session.get('fav_color','red')
fav_color=request.session['fav_color']
设置session:
request.session['visits']=visits
删除session:
delrequest.session['fav_color']
如果给出的key在会话中不存在,将抛出KeyError。
判断包含session:
'fav_color'inrequest.session
清除session数据库
pythonmanage.pyclearsessions
附:Django基于自定义cookies的登录,注册,退出功能示例:
#注册
defregist(req):
ifreq.method=='POST':
uf=UserForm(req.POST)
ifuf.is_valid():
#获得表单数据
username=uf.cleaned_data['username']
password=uf.cleaned_data['password']
#添加到数据库
User.objects.create(username=username,password=password)
returnHttpResponse('registsuccess!!')
else:
uf=UserForm()
returnrender_to_response('regist.html',{'uf':uf},context_instance=RequestContext(req))
#登陆
deflogin(req):
ifreq.method=='POST':
uf=UserForm(req.POST)
ifuf.is_valid():
#获取表单用户密码
username=uf.cleaned_data['username']
password=uf.cleaned_data['password']
#获取的表单数据与数据库进行比较
user=User.objects.filter(username__exact=username,password__exact=password)
ifuser:
#比较成功,跳转index
response=HttpResponseRedirect('/online/index/')
#将username写入浏览器cookie,失效时间为3600
response.set_cookie('username',username,3600)
returnresponse
else:
#比较失败,还在login
returnHttpResponseRedirect('/online/login/')
else:
uf=UserForm()
returnrender_to_response('login.html',{'uf':uf},context_instance=RequestContext(req))
#登陆成功
defindex(req):
username=req.COOKIES.get('username','')
returnrender_to_response('index.html',{'username':username})
#退出
deflogout(req):
response=HttpResponse('logout!!')
#清理cookie里保存username
response.delete_cookie('username')
returnresponse
希望本文所述对大家基于Django框架的Python程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。