首页 > 编程 > Python > 正文

django用户注册、登录、注销和用户扩展的示例

2020-02-22 23:29:33
字体:
来源:转载
供稿:网友

用户部分是一个网站的基本功能,django对这部分进行了很好的封装,我们只需要在django的基础上做些简单的修改就可以达到我们想要的效果

首先我假设你对django的session、cookie和数据库、admin部分都有一定的了解,不了解的可以参考这个教程:http://djangobook.py3k.cn/2.0/

1、用户登录:

首先假设有这样的登录界面:

处理登录的视图代码如下:

def userLogin(request):   curtime=time.strftime("%Y-%m-%d %H:%M:%S",time.localtime());        if request.method=='POST':     print("POST")     username=request.POST.get('name','')     password=request.POST.get('password','')     user= auth.authenticate(username=username,password=password)#a***********     if user and user.is_active:       auth.login(request, user)#b************       return HttpResponseRedirect("/user")           return render_to_response("blog/userlogin.html",RequestContext(request,{'curtime':curtime}))  

注:a、这里是用django自己的auth框架验证用户名和密码,有人会说,这样太不灵活了,我想用邮箱登录呢?后面我们会说直接用django.contrib.auth.models.User 模型来直接操作用户数据,这样就可以做自己想要的验证了。
b、用户信息被验证无误后需要把用户登录的信息写入session中

2、用户注销

注销比较简单,只需要在session中删除对应的user信息就ok了

def userLogout(request):   auth.logout(request)   return HttpResponseRedirect('/user') 

3、用户注册

注册的界面如下:

用户名、密码、邮箱是基本的注册信息,这是django自带的,下面的电话是扩展的用户信息,至于这么扩展用户信息,一会会讲,先透露下我采用的是profile的扩展方式(个人喜好吧,我觉得这种方式简单明了)

注册的视图view代码:

def userRegister(request):   curtime=time.strftime("%Y-%m-%d %H:%M:%S",time.localtime());      if request.user.is_authenticated():#a*******************     return HttpResponseRedirect("/user")   try:     if request.method=='POST':       username=request.POST.get('name','')       password1=request.POST.get('password1','')       password2=request.POST.get('password2','')       email=request.POST.get('email','')       phone=request.POST.get('phone','')       errors=[]              registerForm=RegisterForm({'username':username,'password1':password1,'password2':password2,'email':email})#b********       if not registerForm.is_valid():         errors.extend(registerForm.errors.values())         return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime,'username':username,'email':email,'errors':errors}))       if password1!=password2:         errors.append("两次输入的密码不一致!")         return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime,'username':username,'email':email,'errors':errors}))                filterResult=User.objects.filter(username=username)#c************       if len(filterResult)>0:         errors.append("用户名已存在")         return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime,'username':username,'email':email,'errors':errors}))              user=User()#d************************       user.username=username       user.set_password(password1)       user.email=email       user.save()       #用户扩展信息 profile       profile=UserProfile()#e*************************       profile.user_id=user.id       profile.phone=phone       profile.save()       #登录前需要先验证       newUser=auth.authenticate(username=username,password=password1)#f***************       if newUser is not None:         auth.login(request, newUser)#g*******************         return HttpResponseRedirect("/user")   except Exception,e:     errors.append(str(e))     return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime,'username':username,'email':email,'errors':errors}))      return render_to_response("blog/userregister.html",RequestContext(request,{'curtime':curtime}))             
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表