解析get请求中的query参数[127.0.0.1:8000/myview/?page=10&id=1001](http://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请求提交数据
Title
表单页面
3.视图响应
3-1.HTTPResponse
HTTPResponse # 用于返回字符串
3-2.JsonResponse
JsonResponse # 返回json字符串
3-3.render
from django.shortcuts import render
render(request,'html页面',需要传入页面的参数)
# 返回可渲染的html页面 状态码为200
3-4.重定向redirect
frm django.shortcuts import redirect
redirect(to, permanent=False)
# 一个重定向,浏览器通过该状态码自动跳转到一个新的路由地址,默认返回响应状态码 302
permanent 为 true则返回301状态码
302:临时重定向,旧地址资源临时不能用了,搜索引擎只会暂时抓取新地址的内容而保存旧的地址。
301:永久重定向,旧地址资源已经不复存在,搜索引擎不光会抓取新地址的内容,还会替换旧地址为新地址
4.CBV类视图
是将一个页面所需的视图函数都写在一个类中 根据页面发出的请求响应相应的函数
# 注册视图
class RegisterView(View):
def get(self,request):
return render(request,'register.html')
def post(self,request):
# 获取表单中提交的账号密码
user = request.POST.get('user')
pwd = request.POST.get('pwd')
# 保存账号密码到数据库中,可能出现异常所以要进行异常处理
try:
# 将数据存储到数据库内
Users.objects.create(user = user,pwd = pwd)
except Exception as e:
print(e)
return HttpResponse("账号密码注册失败")
# 重定向到登录页面
return redirect('/login/')
# 路由页面
path('login/', views.LoginView.as_view()),
对应路由此时设置为,需要使用`as_view`函数进行实例化
实现数据的存储与提取对比的视图层代码
from django.shortcuts import render,redirect
from django.views import View
from django.http import HttpResponse
from myapp.models import Users
# Create your views here.
# 注册视图
class RegisterView(View):
def get(self,request):
return render(request,'register.html')
def post(self,request):
# 获取表单中提交的账号密码
user = request.POST.get('user')
pwd = request.POST.get('pwd')
# 保存账号密码到数据库中,可能出现异常所以要进行异常处理
try:
# 将数据存储到数据库内
Users.objects.create(user = user,pwd = pwd)
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")
pwd = request.POST.get("pwd")
# 查看数据库中是否存在账号为user的数据
try:
# 查询用户名 与 表单中输入的用户名一致的数据
user_data = Users.objects.get(user=user1)
except Exception as e:
print(e)
return HttpResponse("账号不存在")
if pwd == user_data.pwd:
# 重定向到主页面
return redirect('/index/')
else:
return HttpResponse("密码错误")
# 主视图
class IndexView(View):
def get(self,request):
return render(request,"index.html")
报错及处理
1.解决CSRF问题的2种方法:
1.注释中间件中与CSRF相关的中间件
2.在表单中加上{% csrf_token %}
2.No open field
找不到文件,打开的文件路径错误
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)