Django框架自定义session处理操作示例 本文实例讲述了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程序设计有所帮助。