先把老師做好的register.html放在Template文件夾弦蹂,配置個url菠发,再寫個views的類和響應函數(shù)艺蝴,
class RegisterView(View):
def get(self,request):
return render(request,"register.html",{})
改下login.html和index.html的超鏈接惋鸥, <li><a href="{% url 'register' %}">[注冊]</a></li>類似于這樣杂穷。然后發(fā)現(xiàn)頁面沒有格式。在html文件第三行<html>和<head>卦绣,加上{% load staticfiles %}耐量,這樣把css、js的路徑改為類似
<link rel="stylesheet" type="text/css" href="{% static 'css/login.css' %}">
由于在settings.py里有STATIC_URL = '/static/'滤港。這樣以后如果靜態(tài)文件位置變了只需要改settings.py就能改所有的靜態(tài)文件在html文件里的路徑廊蜒。
注冊需要輸入驗證碼,驗證碼功能要使用captcha的django插件溅漾。去github看了下怎么安裝山叮,用pip就行,但是這里要用0.4.6,否則據(jù)說會出錯添履。安裝完了要按使用說明在urls里增加一行屁倔,應用include
from django.conf.urls import url, include
from django.contrib import admin
from django.views.generic import TemplateView
from users.views import LoginView, RegisterView
import xadmin
from apps.users.views import login
urlpatterns = [
url(r'^xadmin/', xadmin.site.urls),
url('^$', TemplateView.as_view(template_name="index.html"),name="index"),
url('^login/$', LoginView.as_view(),name="login"), #as_view()方法判斷是post還是get然后返回響應函數(shù)名
url('^register/$', RegisterView.as_view(),name="register"),
url(r'^captcha/', include('captcha.urls')),
]
然后makemigrations和migrate,生成了一個captcha的表暮胧。在forms.py里增加一個類用于登陸
class RegisterForm(forms.Form):
email = forms.EmailField(required=True)
password = forms.CharField(required=True, min_length=5)
captcha = CaptchaField(required=True)
在views.py里
class RegisterView(View):
def get(self,request):
register_form = RegisterForm()
return render(request,"register.html",{'register_form':register_form})
生成一個RegisterForm()實例锐借,傳入前端。在前端驗證碼的label下把它寫進去
<div class="form-group marb8 captcha1 ">
<label>驗 證 碼</label>
{{ register_form.captcha }}
</div>
這樣就能生成驗證碼了往衷,生成的驗證碼會保存在數(shù)據(jù)庫的captcha表钞翔,也生成在網(wǎng)頁上顯示的一個圖片,和一個hashkey席舍。需要生成驗證碼時,后臺會在數(shù)據(jù)庫里新生成一行俺亮,其中包括驗證碼和哈希key,哈希key唯一脚曾,是驗證碼的標識。傳到前臺的是一個圖片和生成的哈希key本讥。用戶在前臺輸入驗證碼后再把哈希key和用戶輸入的驗證碼傳回后臺的數(shù)據(jù)庫表作聯(lián)合查詢珊泳,如果沒有結果則輸入錯誤鲁冯。
RegisterForm繼承自forms色查,可以直接用is_valid方法檢驗輸入是否合理薯演,除了郵箱密碼設定的要求秧了,連驗證碼也檢查是不是和后臺生成的一致跨扮。要把request.POST傳進去。然后在if register_form.is_valid()為True的條件下把用戶輸入保存到數(shù)據(jù)庫验毡。但密碼不能以明文存入數(shù)據(jù)庫衡创,可以調用make_password函數(shù)把明文密碼轉換成密文晶通。
from django.contrib.auth.hashers import make_password
class RegisterView(View):
def get(self,request):
register_form = RegisterForm()
return render(request,"register.html",{'register_form':register_form})
def post(self,request):
register_form = RegisterForm(request.POST)
if register_form.is_valid():
user_name = request.POST.get("username","")
pass_word = request.POST.get("password","")
user_profile = UserProfile()
user_profile.username = user_name
user_profile.email = user_name
user_profile.password = make_password(pass_word)
user_profile.save()
不要忘了在register.html文件里的form開通要寫method = “post”,action也要寫狮辽。結尾要寫{% csrf_token %}。
<form id="email_register_form" method="post" action="{% url 'register' %}" autocomplete="off">