美文网首页
Django用户扩展

Django用户扩展

作者: syp_xp | 来源:发表于2017-05-01 01:06 被阅读61次

    本文转自http://blog.csdn.net/clh604/article/details/9269449
    另外可以参考 http://www.cnblogs.com/caseast/p/5909987.html

    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中
    1. 用户注销
      注销比较简单,只需要在session中删除对应的user信息就ok了
    def userLogout(request):  
        auth.logout(request)  
        return HttpResponseRedirect('/user')  
    
    1. 用户注册
      注册的界面如下:



      用户名、密码、邮箱是基本的注册信息,这是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}))  
    

    注:
    a、验证用户是否登录了,已经登录就没必要注册了(当然这只是练习使用,实际生产情况可能不一样)
    b、注册表单传过来的数据需要一些基本的验证,怎么验证表单数据可以参考这个教程:http://djangobook.py3k.cn/2.0/chapter07/
    c、用User模型查找要注册的用户名是否存在,如果用户已经存在就需要提示注册的客户更换用户名
    d、直接利用User模型把通过验证的用户数据存入数据库,需要注意的是,保存密码信息时需要使用set_password方法(因为这里有个加密的过程)
    e、存储用户的扩展信息(这里是用户的电话号码),这里用到自定义的用户扩展模型UserProfile,具体怎么扩展用户后面会讲
    f、用户登录前需要先进行验证,要不然会出错
    g、用户登录

    1. 用户扩展
      网上关于django的用户扩展方式有好几种,个人比较倾向于Profile的方式,主要是这种方式简单清楚,扩展步骤如下:
      A、在你App的models中新建一个UserProfile模型
    from django.contrib.auth.models import User        
    class UserProfile(models.Model):  
        user=models.OneToOneField(User,unique=True,verbose_name=('用户'))#a******  
        phone=models.CharField(max_length=20)#b******  
    

    注:

    • a、UserProfile其实就是一个普通的model,然后通过这一句与django的User模型建立联系
    • b、扩展的用户信息
    • B、Python manage.py syncdb 在数据库内创建userprofile的表
    • C、如何调用user的扩展信息呢?很简单,先得到user,然后通过user提供的get_profile()来得到profile对象,比如
      user.get_profile().phone
    • D、如何更新和存储user的profile信息呢,其实在之前的用户注册部分我们已经使用了这样的功能,userprofile其实也是一个model,我们只要通过user模型得到user的id,就可以通过UserProfile模型来操作对应的profile信息:
    user=User()  
    user.username=username  
    user.set_password(password1)  
    user.email=email  
    user.save()  
    #用户扩展信息 profile  
    profile=UserProfile()  
    profile.user_id=user.id  
    profile.phone=phone  
    profile.save()  
    
    • E、我们能在程序中操作用户扩展信息了,那我想在admin后台中编辑扩展信息要怎么做呢:
      很简单,只要在你的APP的admin.py中添加下面的语句就行了
    class UserProfileInline(admin.StackedInline):  
        model=UserProfile  
        fk_name='user'  
        max_num=1    
    class UserProfileAdmin(UserAdmin):  
        inlines = [UserProfileInline, ]  
    admin.site.unregister(User)  
    admin.site.register(User,UserProfileAdmin)  
    

    这是我学习django时的一些经验,也许不全对,仅供参考

    相关文章

      网友评论

          本文标题:Django用户扩展

          本文链接:https://www.haomeiwen.com/subject/ekhftxtx.html