本文实例讲述了Django框架自定义session处理操作。分享给大家供大家参考,具体如下:django
本文实例讲述了Django框架自定义session处理操作。分享给大家供大家参考,具体如下:
django有自己的一套session框架,有他自己的机制处理,但这通常是在全新构件系统的时候才会用到。如果是一套已有的系统,现在重新想用django做成web版的,由于以往的数据库是已经设计好,不能修改其表结构,但可以增加表,因为用django必须有django自己的一些系统表,这些是必须添加到原有的数据库中的,我们可以通过 mange.py syncdb 来创建.
| auth_group | auth_group_permissions | auth_permission | auth_user | auth_user_groups | auth_user_user_permissions | blog_content | django_content_type | django_session | django_site
当然,这些表各自有自己的作用,比如django_session 就是用来管理session 的。
如果你用djiango自身的session来管理用户是否登录,可以用系统自带的装饰方法:@login_required
但如果是你自己在原来的系统上开发,原来的用户管理肯定不可能是django一样的。所以得自己写一个类似@login_required
方法来判断用户是否已经登录.
假设有一个user model 是用户的Class ,并在 models中已经定义
class UserID(models.Model):
login_id=models.CharField(max_length=32)
login_pwd=models.CharField(max_length=32,blank=False)
nickname=models.CharField(max_length=50)
登录的方法
def checklogin(request):
""" 用户登录简易判断 """
try:
login_id=request.POST.get('user','')
userpwd=request.POST.get('password','')
existuser=models.UserID.objects.get(login_id=login_id,login_pwd=userpwd)
#假设存在此用户,就要给session 赋值
request.session['myuser']=existuser
except:
.....
到此为止,自己定义的登录过程已经完成,并且记录了session值。如果在其他方法需要检查用户是否登录时,如何写自己的判断方法呢?
def check_session(func):
''' check user session '''
def wrapper(request,*args, **kv):
userinfo=request.session.get('myuser',None)
if not userinfo:
return HttpResponseRedirect('/login') #没有登录,则跳转到登录页面
return func(request,*args, **kv)
return wrapper
在其他需要检查用户是否登录的views方法上,加上这个装饰就可以了。
@check_session
def get_all_infomation(request):
context={}
context.update(csrf(request))
......
return render_to_response('customer/all_information.html',context)
这样,如果用户没有登录的话,就会跳转到登录页面,用装饰实现了自己的用户 session判断。
当然有人会问,我要注销登录怎么处理呢?简单,django的session其实就是dict.所以可以用如下方法注销
def logout(request):
try:
del request.session['myuser']
except KeyError:
pass
return HttpResponseRedirect('/')
希望本文所述对大家基于Django框架的Python程序设计有所帮助。
Django框架 自定义 session处理