用戶部分是一個(gè)網(wǎng)站的基本功能,django對(duì)這部分進(jìn)行了很好的封裝,我們只需要在django的基礎(chǔ)上做些簡(jiǎn)單的修改就可以達(dá)到我們想要的效果
首先我假設(shè)你對(duì)django的session、cookie和數(shù)據(jù)庫(kù)、admin部分都有一定的了解,不了解的可以參考這個(gè)教程:http://djangobook.py3k.cn/2.0/
1、用戶登錄:
首先假設(shè)有這樣的登錄界面:

處理登錄的視圖代碼如下:
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框架驗(yàn)證用戶名和密碼,有人會(huì)說(shuō),這樣太不靈活了,我想用郵箱登錄呢?后面我們會(huì)說(shuō)直接用django.contrib.auth.models.User 模型來(lái)直接操作用戶數(shù)據(jù),這樣就可以做自己想要的驗(yàn)證了。
b、用戶信息被驗(yàn)證無(wú)誤后需要把用戶登錄的信息寫入session中
2、用戶注銷
注銷比較簡(jiǎn)單,只需要在session中刪除對(duì)應(yīng)的user信息就ok了
def userLogout(request): auth.logout(request) return HttpResponseRedirect('/user') 3、用戶注冊(cè)
注冊(cè)的界面如下:

用戶名、密碼、郵箱是基本的注冊(cè)信息,這是django自帶的,下面的電話是擴(kuò)展的用戶信息,至于這么擴(kuò)展用戶信息,一會(huì)會(huì)講,先透露下我采用的是profile的擴(kuò)展方式(個(gè)人喜好吧,我覺得這種方式簡(jiǎn)單明了)
注冊(cè)的視圖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() #用戶擴(kuò)展信息 profile profile=UserProfile()#e************************* profile.user_id=user.id profile.phone=phone profile.save() #登錄前需要先驗(yàn)證 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}))
新聞熱點(diǎn)
疑難解答
圖片精選