登录功能
模板页面
sign/templates/index.html
html
<!DOCTYPE html>
<html>
<head>
<title>Login Page</title>
</head>
<body>
<h1>发布会管理</h1>
<form action="/login/" method="post">
<label for="username">Username:</label>
<input type="text" id="username" name="username" required><br><br>
<label for="password">Password:</label>
<input type="password" id="password" name="password" required><br><br>
<button id="btn" type="submit">登录</button>
{% csrf_token %}
</form>
</body>
</html>
备注:
CSRF verification failed. Request aborted.
data:image/s3,"s3://crabby-images/b802a/b802a31946cd1464ef4b3e34879151ba411adf49" alt=""
表格需要加一个 {% csrf_token %} 的标签。csrf 全称是 Cross Site Request Forgery。这是 Django 提供的防止伪装提交请求的功能。POST 方法提交的表格,必须有此标签。
data:image/s3,"s3://crabby-images/ff60d/ff60d8c7c5ea7ed97d268ed3323527d5100b945a" alt=""
再次使用POST请求,可以看到客户端提交带有一个token值
data:image/s3,"s3://crabby-images/2e0c0/2e0c022983f53ad4322b5d7dce81d4fdc24327a0" alt=""
登录视图
python
from django.http import HttpResponse, Http404
from django.shortcuts import render
# Create your views here.
def index(request):
return render(request,"index.html")
def login(request):
if request.method=='POST':
username=request.POST.get("username",'')
password=request.POST.get("password",'')
if username=='admin' and password=="admin123":
return HttpResponse("登录成功")
else:
return render(request,'index.html',context={'error':'username or password error!'})
向服务器提交请求时,服务器可以通过request获取用户提交值
如获取POST请求中提交的name为username的值
<input type="text" id="username" name="username" required><br><br>
request.POST["username"]
或者 request.POST.get('username','')
获取请求名称:request.method
这里用返回了一个字符串
return HttpResponse("登录成功")
事件管理
模板页面
sign/templatesevent_manage.html
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Event Manage Page</title>
</head>
<body>
<h1>嗨 {{user}} 欢迎</h1>
</body>
</html>
视图函数
python
from django.http import HttpResponse, Http404,HttpResponseRedirect
from django.shortcuts import render
# Create your views here.
def index(request):
return render(request,"index.html")
def login(request):
if request.method=='POST':
username=request.POST.get("username",'')
password=request.POST.get("password",'')
if username=='admin' and password=="admin123":
response=HttpResponseRedirect('/event_manage/')
response.set_cookie('user',username,3600)
return response
else:
return render(request,'index.html',context={'error':'username or password error!'})
def event_manage(request):
username=request.COOKIES.get('user','')
return render(request,'event_manage.html',{"user":username})
httpresponserediect为重定向,登录后页面被重定向至实践管理页面
data:image/s3,"s3://crabby-images/bfbcf/bfbcf1556268bc62cf961619ac54c361081ad449" alt=""
这里采用response.set_cookie方法为客户端设置了cookie user=username
使用request.COOKIES.get()方法获取到客户端访问时带的cookie。
如果想给模板传值,需要在render第三个参数提供字典,字段名:值,
在模板中采用双引号{{字段名}}读取返回值。
也可以使用session
response.session["user"]=username
data:image/s3,"s3://crabby-images/2a32b/2a32b9c76e5114fc47ac6933ffe837b3c7ad09f0" alt=""
要用sesssion需要创建django自带的数据表session
控制台执行python manage.py migrate
data:image/s3,"s3://crabby-images/a638d/a638d49a2e0ab4ab6b189f3f850933c6d4d66b59" alt=""
重新登陆,可以看到设置的sessionid
data:image/s3,"s3://crabby-images/3b6b0/3b6b0dab64e0d14cabecd97e6ae66e86095a1cf3" alt=""
使用django认证
创建一个admin用户,这里用的是django自带的管理员账号功能。
data:image/s3,"s3://crabby-images/3f58c/3f58c09dcd11f8cad7a9faee1639134a067d1994" alt=""
运行项目,访问http://127.0.0.1:8000/admin
使用创建的账号登录,并创建一个user
data:image/s3,"s3://crabby-images/f66b5/f66b5a2d2bc4d4bc89edf599e4f8871e24707c09" alt=""
修改登录函数使用django的认证
data:image/s3,"s3://crabby-images/e2362/e23624bc75677122b11a43ee56e2438e67fed933" alt=""
输入正确账号密码可以登录,输出不存在账号密码登录失败。
设置视图仅登录后可用
data:image/s3,"s3://crabby-images/69c78/69c7812bbfe2da96fb4ed05ad8fd9cde69c9e13a" alt=""
设置装饰loginrequired后,直接访问视图会报错
data:image/s3,"s3://crabby-images/0bd25/0bd25964c0b8f73f69845e82beda377291e077c7" alt=""