【Python Web】django框架(四)模板语法及请求响应

模板语法

本质上:在HTML中写一些占位符,由数据对这些占位符进行替换和处理。

  • 视图函数中的render内部

    • 读取含有模板语法的HTML文件
    • 内部进行渲染,最终得到只包含HTML标签的字符串
    • 最后将渲染完成的字符串返回给用户浏览器
  • 数据替换
    在这里插入图片描述
    在这里插入图片描述

  • if语法
    在这里插入图片描述

  • 效果展示
    在这里插入图片描述

请求和响应

请求

  • 获取请求方式 GET/POST
print(request.method)
  • 在url上传递值
print(request.GET)
  • 在请求体中提交数据
print(request.POST)

响应

  • 内容字符串返回给请求者
return HttpResponse("返回")
  • 读取HTML的内容+渲染 ——> 将字符串内容返回给用户浏览器
return render(request, 'something.html',{"title": "来了"})
  • 让浏览器重定向到其他页面
return redirect("https://www.baidu.com")

案例:用户登录

  • 对应关系

在这里插入图片描述

  • views.py
import requests
from django.shortcuts import render, HttpResponse, redirect

def login(request):
    if request.method == "GET":
        return render(request, "login.html")
    # 如果是POST请求,获取用户提交的数据
    # print(request.POST)
    username = request.POST.get("user")
    password = request.POST.get("pwd")
    if username == "root" and password == "123":
        return HttpResponse("登录成功")
        # return HttpResponse("登陆失败")
    return render(request, 'login.html',{"error_msg": "用户名或密码错误"})
  • login.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<h1>用户登录</h1>
<form method="post" action="/login/">

    {% csrf_token %}

    <input type="text" name="user" placeholder="用户名">
    <input type="password" name="pwd" placeholder="密码">
    <input type="submit" value="提交">
    <span style="color: red">{{ error_msg }}</span>
</form>

</body>
</html>

  • CSRF 相当于多了一层验证
    在这里插入图片描述
  • 在form表单中加上一句
    在这里插入图片描述

版权声明:本文为qq_51670115原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。