1. 程式人生 > >django使用者註冊、登入、登出和使用者擴充套件

django使用者註冊、登入、登出和使用者擴充套件

使用者部分是一個網站的基本功能,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}))

注:

a、驗證使用者是否登入了,已經登入就沒必要註冊了(當然這只是練習使用,實際生產情況可能不一樣)

c、用User模型查詢要註冊的使用者名稱是否存在,如果使用者已經存在就需要提示註冊的客戶更換使用者名稱

d、直接利用User模型把通過驗證的使用者資料存入資料庫,需要注意的是,儲存密碼資訊時需要使用set_password方法(因為這裡有個加密的過程)

e、儲存使用者的擴充套件資訊(這裡是使用者的電話號碼),這裡用到自定義的使用者擴充套件模型UserProfile,具體怎麼擴充套件使用者後面會講

f、使用者登入前需要先進行驗證,要不然會出錯

g、使用者登入

4、使用者擴充套件

網上關於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時的一些經驗,也許不全對,僅供參考