WTForms本身既可以用来渲染html控件,可以单独用来验证表单,如果要支持JSON,可以用1楼的hack。
我推荐你用flask_wtf,这个插件,这个插件是对wtfoms的进一步封装,支持form,也支持json,CSRF,文件上传。我在项目里,页面渲染和WebService都是用的这个插件。
例子:
form.py
from flask_wtf import FlaskForm
from wtforms import StringField, IntegerField
from wtforms.validators import Length, StopValidation
class MyForm(FlaskForm):
# 字段
name = StringField(validators=[Length(min=1, max=20, message="name长度需在1-20个字符间")])
name2 = IntegerField()
# 自定义验证
def validate_age(self, field):
# 根据name2查询model
# ......
model = None
if not model:
# StopValidateion不需要自己捕捉
raise StopValidation("name2信息不存在")
view.py
@app.route('/api/get_obj_info', methods=["GET", "POST"]):
def get_obj_info():
form = MyForm()
if request.method == "GET":
return jsonify({
# xxxxx
})
# validate_on_submit 会自动调用“validate_字段”这些验证方法
# 验证失败后返回表单验证的错误消息
if form.validate_on_submit():
return jsonify({
"status": "success",
"msg": "xxxx"
})
# 验证未通过
return jsonify({
"status": "failed":
"msg": "xxxx",
"error": form.errors
})
前台POST数据:
{
name: "小明",
name2: "管理"
}