第三单元 视图层
1.创建超级用户添加数据
1.创建超级用户:python manage.py createsuperuser
2.在子应用的admin.py文件中添加代码,注册表,不然admin控制台没办法管理这个表
from django.contrib import admin
from myapp.models import Game
# Register your models here.
admin.site.register(Game)
2.视图代码编写
from django.shortcuts import render
from django.http import HttpResponse
from myapp.models import Game
# Create your views here.
# 视图函数
def MyView(request):
# 3.MVT三层联动
# 通过Game模型类,取出数据块中的数据(ORM操作),取出所有角色信息
game_data = Game.objects.all()
content = { # 传递给页面的数据,字典
'games': game_data,
}
# render返回一个模板页面
return render(request, 'index2.html', content)
3.配置路由
from django.contrib import admin
from django.urls import path
from myapp import views
# 主路由
urlpatterns = [
path('admin/', admin.site.urls),
path('myview/', views.MyView),
]
视图层
1视图请求
视图函数一般用来接收一个Web请求HttpRequest
,之后返回一个Web响应HttpResponse
1.1GET请求处理
解析get请求中的query参数127.0.0.1:8000/myview/?page=10&id=1001
# 解析GET请求
def MyView(request):
page = request.GET.get('page')
id = request.GET.get('id')
return HttpResponse(f"这是第一个视图,当前页数为{page},当前id为{id}")
2.POST请求处理
编写表单页面,在表单中发送post请求提交数据
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h3>表单页面</h3>
<form method="post" action="/myview2/">
{% csrf_token %}
账号: <input type="text" name="user">
密码: <input type="password" name="pwd">
<input type="submit" value="提交">
</form>
</body>
</html>
# 解析POST请求
def MyView2(request):
user = request.POST.get('user')
pwd = request.POST.get('pwd')
return HttpResponse(f"这是第二个视图,账号:{user},密码:{pwd}")
解决CSRF问题的方法有两个
第一种解决方法{% csrf_token %}
第二种解决方法在主应用上settings
里
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
# 'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
3.POST请求处理表单
1.在request.POST
中需要注意,某些情况下,使用 POST 提交数据的表单数据可能是多个值,类似复选框CheckBox
,直接使用request.POST.get()
进行获取是有一些问题的,比如修改模板页面如下所示
4.视图响应
1.HTTPResponse
一个视图的返回值经常是为了向用户返回一个HttpResponse
响应,有如下常用的可以返回HttpResponse
的函数
2.JsonResponse
from django.http import JsonResponse
JsonResponse({'a':1, 'b':2})
# 返回一个Json字符串
3.重定向概念及…render…redirect
1.request: 固定参数,响应的 request 请求,来自于参数部分接收的 HttpRequest
今天讲的重定向概念注册登录主页面案例
实现登录注册功能。
案例
注册:用户输入账号密码以后提交到服务器,服务器将账号密码保存到数据库中,然后重定向到登录页面。
登录:用户输入账号密码,服务器判断账号密码是否存在,如果存在的话登录成功转跳到主页面。
分析
需要3个页面、需要3个类视图(5个视图方法)。
注册类视图:
get视图方法:获取注册页面。
post视图方法:提交注册的账号密码,并且转跳到到登录页面。
登录类视图:
get视图方法:获取登录页面。
post视图方法:提交登录的账号密码,并且转跳到到主页面。
主页面类视图:
get视图方法:获取主页面
from django.shortcuts import render,redirect
from django.views import View
from django.http import HttpResponse
from myapp.models import Users
# 注册视图
class RegisterView(View):
# 返回注册页面
def get(self,request):
return render(request,"register.html")
# 提交账号密码并保存到数据库
def post(selfs,request):
# 获取表单中提交的帐号密码
user1=request.POST.get("user")
pwd1=request.POST.get("pwd")
# 保存账号密码到数据库中,可能出现异常所以要进行异常处理
try:
# 新增数据
Users.objects.create(user=user1,pwd=pwd1)
except Exception as e:
print(e)
return HttpResponse("账号密码注册失败")
# 重定向到登录页面
return redirect("/login/")
# 登录视图
class LoginView(View):
def get(self,request):
return render(request,"login.html")
# 提交账号密码,验证账号密码是否存在
def post(self,request):
user1=request.POST.get("user")
pwd1=request.POST.get("pwd")
# 查看数据库中是否在账号为user1的数据
try:
# 查询用户名与表单中输入的用户名一致的数据
user_data=Users.objects.get(user=user1)
except Exception as e:
print(e)
return HttpResponse("账号不存在")
# 用户存在,判断密码是否一致
if pwd1==user_data.pwd:
# 重定向到主页面
return redirect('/index/')
else:
return HttpResponse("密码错误")
# 主页面
class IndexView(View):
# 获取主页面
def get(self,request):
return render(request,"index.html")
3.1 CBV类视图
1.FBV、CBV概念
CBV就是在视图里使用类处理请求
from django.views import View
class RegisterView(View):
# 返回注册页面
def get(self,request):
return render(request,"register.html")
# 提交账号密码并保存到数据库
def post(selfs,request):
# 获取表单中提交的帐号密码
user1=request.POST.get("user")
pwd1=request.POST.get("pwd")