>  기사  >  백엔드 개발  >  Python의 Flask 애플리케이션(양식 처리)

Python의 Flask 애플리케이션(양식 처리)

不言
不言앞으로
2018-11-15 14:42:013425검색

이 기사의 내용은 Python의 플라스크 응용 프로그램(양식 처리)에 대한 내용입니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

1. 왜 Flask-WTF를 사용하나요?

요청 개체는 클라이언트가 보낸 모든 요청 정보를 노출합니다. 특히 request.form은 POST 요청으로 제출된 양식 데이터에 액세스할 수 있습니다.
Flask의 요청 개체가 제공하는 지원은 웹 양식을 처리하는 데 충분하지만 여전히 단조롭고 반복적인 작업이 많이 있습니다.
양식용 HTML 코드 생성과 제출된 양식 데이터 유효성 검사가 좋은 예입니다.

장점:

Flask-WTF 확장 기능을 사용하면 웹 양식 작업이 더욱 즐거운 경험이 됩니다. 이 확장은 프레임워크 독립적인 WTForms 패키지를 래핑하는 Flask 통합입니다.

2. 양식 처리란 무엇인가요?

웹 페이지에서는 사용자와 상호작용하기 위해 일부 양식이 항상 나타나야 합니다.
flask는 플라스크가 양식 데이터를 보다 쉽게 ​​관리하고 운영할 수 있도록 WTForm 양식 라이브러리를 설계했습니다.

WTForm에서 가장 중요한 개념은 다음과 같습니다.

1) Form 클래스, 개발자 정의 양식은 Form 클래스 또는 해당 하위 클래스에서 상속되어야 합니다.
Form 클래스의 주요 기능은 포함된 Field 클래스를 통해 양식의 데이터에 빠르게 액세스할 수 있도록 하는 것입니다.

2) 다양한 필드 수업, 즉 필드. 일반적으로 각 Field 클래스는 입력 HTML 태그에 해당합니다.
예를 들어, BooleanField와 같이 WTForm과 함께 제공되는 일부 Field 클래스는 에 해당하고
SubmitField는 에 해당합니다.

3) 유효성 검사기 클래스입니다. 이 클래스는 사용자가 입력한 데이터의 유효성을 확인하는 데 사용됩니다.
예를 들어, 길이 유효성 검사기를 사용하여 입력 데이터의 길이를 확인하고,
FileAllowed를 사용하여 업로드된 파일 유형을 확인할 수 있습니다.

또한 csfr(교차 사이트 요청 위조) 공격을 방지하기 위해 플라스크에서는 플라스크-wtf를 사용하기 전에 앱에서 기본적으로 secret_key를 설정해야 합니다. 이를 구성하는 가장 간단한 방법은 app.config['SECRET_KEY'] = 'xxxx'를 사용하는 것입니다.

3. 공통 필드 클래스

 PasswordField  Password 필드, 입력을 작은 검은색 점으로 자동 변환

  DateField    텍스트 필드, 형식 요구 사항은 datetime.date

  IntergerField  텍스트 필드의 형식 요구사항은 정수

 DecimalField 텍스트 필드, 형식 요구 사항은 십진수와 동일합니다.Decimal

 FloatField  텍스트 필드, 값은 부동 소수점 숫자입니다.

 BooleanField  박스를 선택하면 값이 True 또는 False입니다

 RadioField   라디오 버튼 세트

  SelectField 드롭다운 목록, 주의해야 합니다. 드롭다운 옵션을 결정하는 것은Choices 매개변수이지만 HTML의

 MultipleSelectField 여러 값이 포함된 드롭다운 목록

Validator 확인 기능

Validator는 확인 기능에 필드를 바인딩한 후 양식으로 데이터를 받기 전에 데이터를 확인합니다. , 데이터는 확인이 성공한 경우에만 수신됩니다. 검증 기능은 다음과 같습니다. 특정 검증자에게는 다른 매개변수가 필요할 수 있습니다. 여기서는 일반적으로 사용되는 몇 가지만 설명합니다. 자세한 사용법은 각 검증자 클래스에 필요한 매개변수를 확인하세요. :

*기본적으로 모든 유효성 검사기에는 입력 데이터가 유효성 검사기의 요구 사항을 충족하지 않을 때 표시되는 메시지를 나타내는 메시지 매개 변수가 있습니다.

 이메일 이메일 주소의 적법성을 확인합니다. 필수 정규 패턴은 ^.+@(12+)$

 EqualTo 두 필드의 값을 비교합니다. 일반적으로 비밀번호를 두 번 입력하면 fieldname 매개변수를 쓸 수 있지만 이는 동일한 형식으로 다른 필드의 필드 이름을 가리키는 문자열 변수라는 점에 유의하세요.

  IPAddress IPv4 주소를 확인하세요. 매개변수의 기본값은 ipv4=True, ipv6=False입니다. ipv6을 확인하려면 이 두 매개변수를 반대로 설정하면 됩니다.

  길이 입력 문자열의 길이를 확인합니다. 설정할 길이의 하한과 상한을 나타내는 두 개의 매개변수가 있을 수 있습니다. 매개변수 유형은 INT가 아니라 문자열입니다.

NumberRange 확인하세요. 입력 숫자가 범위 내에 있는지 여부 숫자의 상한과 하한을 나타내는 두 개의 매개 변수가 있을 수 있습니다. 그런 다음 두 가지 형식을 설정할 수 있습니다. 이 유효성 검사기의 메시지 매개 변수에서 %(min)s 및 %(max)s 부분을 사용하여 이 범위가 무엇인지 알려줍니다. 다른 유효성 검사기에도 비슷한 트릭이 있으므로 소스 코드를 참조할 수 있습니다.

  선택사항  입력값이 없을 경우 동일한 필드의 다른 검증 기능 건너뛰기

  ​​필수

 URL URL을 확인하기 위해 필요한 일반 패턴은 ^[a-z]+://(?P3+)(?P:[0-9]+)?(?P/ .*)?$

 AnyOf  값이 선택적 값 목록에 있는지 확인합니다. 매개변수는 값(선택적 값 목록)입니다. 특히 SelectField와 함께 사용할 경우 SelectField의 선택 항목에 있는 항목의 값이 왜 숫자가 될 수 없는지 모르겠습니다. . 그렇지 않으면 AnyOf의 값 매개변수에 해당 숫자가 있더라도 현재 옵션이 적법한 옵션이라고 인식할 수 없습니다. 나는 NoneOf가 같은 트릭을 가지고 있을지도 모른다고 생각합니다.

 NoneOf 옵션 값 목록에 해당 값이 없는지 확인하세요 ​​

#forms.py文件:用来设定规则
from flask_wtf import FlaskForm
from flask_wtf.file import FileRequired, FileAllowed
from wtforms import StringField, PasswordField, SubmitField, FileField
from wtforms.validators import DataRequired, Length


class LoginForm(FlaskForm):
    name = StringField(
        label="用户名/邮箱/手机号",
        validators=[
            # DataRequired("请输入用户名"),
            Length(3, 20, message="长度不符"),
        ]
    )
    passwd = PasswordField(
        label="密码",
        validators=[
            # DataRequired("请输入密码"),
            Length(3, 20),
        ], )

    file = FileField(
        label="简历",
        validators=[
            FileRequired(),
            FileAllowed(['pdf', 'txt'], 'pdf 能被接收')
        ]
    )
#templates/demo/login.html
nbsp;html>


    <meta>
    <title>Title</title>


    {{ form.hidden_tag() }}     {{ form.name.label }} {{ form.name }}     {{ form.passwd.label }} {{ form.passwd }}     {{ form.file }}     
#主程序
import random
from flask import Flask, redirect, render_template
from forms import LoginForm
from flask_bootstrap import  Bootstrap

app = Flask(__name__)
bootstrap = Bootstrap(app)
app.config['SECRET_KEY'] =  random._urandom(24)

@app.route('/success/')
def success():
    return  "success"

@app.route('/login/', methods=('GET', 'POST'))
def submit():
    # 实例化表单对象;
    form = LoginForm()
    if form.validate_on_submit():
        print(form.data)
        return redirect('/success/')
    return render_template('demo/login.html', form=form)
app.run()

Python의 Flask 애플리케이션(양식 처리)

위 내용은 Python의 Flask 애플리케이션(양식 처리)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제