typhoonpython 2019-11-03
一:表单类
一般我们在html中自己写的表单类似于下面的样子
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>表单</title>
</head>
<body>
    <form action="www.xxx.com" method="POST">
        username:<input type="text" placeholder="username" name="username">
        passowrd:<input type="password" placeholder="password" name="password">
        submit:<input type="submit">
    </form>
</body>
</html># 取值也是 request.POST.get("username")  request.POST.get("password")表单类
from django import forms
class Login_Form(forms.Form):
    username = forms.CharField(label="你的名字",max_length=20)
    password = forms.CharField(label="你的密码",max_length=20)前端代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <form action="user/login/" method="post">
    {% csrf_token %}
    {{ form }}
    <input type="submit" value="Submit" />
</form>
</body>
</html>视图函数
from django.http import HttpResponse
from django.http import JsonResponse
from django.shortcuts import render
from .form_test import Login_Form
def form_test_view(request):   # 如果是post请求,将数据绑定到表单,直接存储在request.POST中,取值普通表单一样。
    if request.method == "POST":
        form = Login_Form(request.POST)
        if form.is_valid():
            # 检验数据的有效性       # 验证过的数据可以通过 form.cleaned_data取得,格式是一个字典       print(form.cleaned_data)           
            return HttpResponse("谢谢提交")
    else:        # 如果是get请求,创建表单实例,将表单中的字段,传递到login.html中,进行渲染,渲染成input文本输入框。
        form = Login_Form()
    return render(request,"login.html",{"form":form})from django.conf.urls import url
from .views import index
from .views import form_test_view
urlpatterns = [
    url(r"^index/",index),
    url(r"^login",form_test_view)
]
 

二:csrf 跨站伪造攻击