Get请求和Post请求
无论是GET还是POST,统一都由视图函数接收请求,通过判断request.method区分具体的请求动作
if request.method =='GET':
# 处理GET请求时的业务逻辑
elif request.method == 'POST ' :
# 处理POST请求的业务逻辑
else:
# 其他请求业务逻辑
获取Get的值
我们可以使用字典的方法来获取我们的值比如
request.GET[‘a’]
,这样来获取 a 的值request.GET.get(a,‘没有找到数据’)
, 这样来保险一点寻找 a 的值,如果没有找到就会返回第二个参数request.GET.getlist(‘a’)
,使用这个方法来获取 a 所有的值,返回为一个列表,之前的方法返回的都是列表内最后的一个值
POST 的表单请求
我们在后端想要接收到消息我们首先需要在前端进行定义,我们在学习的情况下使用表单来递交登陆请求
<form method="post" action="/login">
账户:<input type="text" name="account">
密码:<input type="text" name="password">
<input type="submit" value="登陆">
</form>
取消csrf验证,否则 django 将会拒绝客户端发来的POST请求,然后报错 403
- 我们这里的
action=“login”
表示我们会传送给login路由处理,同理我们亦可以选择自身路由,将命令交给自己处理,然后用 if 判断是否是 POST 请求
暂时关闭 csrf
我们如果没有关闭 django 自带的csrf的话,我们的请求就是无法提交过来的, 我们可以前往 settings.py
中的MIDDLEWARE
中注释掉'django.middleware.csrf.CsrfViewMiddleware'
制作一个登陆界面
- 定义视图功能
# views.py 文件内
from django.http import HttpResponse
def testPost(request):
html = """
<form method="post" action="/testPost">
账户:<input type="text" name="account">
密码:<input type="text" name="password">
<input type="submit" value="登陆">
</form>
"""
if request.method == "POST":
return HttpResponse(f'当前账户为 {request.POST.get("account","错误")}\n密码为 {request.POST.get("password","错误")}')
return HttpResponse(html)
- 去路由内添加我们的视图
# urls.py 文件内
from django.urls import path, re_path
from . import views
urlpatterns = [
path('testPost',views.testPost),
]