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程序设计有所帮助。