当前位置: 首页 > news >正文

达州建网站简单的静态网页代码

达州建网站,简单的静态网页代码,徐州做网站的公司招聘,微商城开发流程1.Tornado_wtform介绍 WTForms是用于Python Web开发的灵活的表单验证喝呈现库。他可以和任何的web框架和模板引擎一起使用。 现在因为前后端分离的原因,一般只用于表单的验证,模板渲染的功能基本不再使用。 2.为什么要表单数据验证 其实前端也是可以进…

1.Tornado_wtform介绍

WTForms是用于Python Web开发的灵活的表单验证喝呈现库。他可以和任何的web框架和模板引擎一起使用。
现在因为前后端分离的原因,一般只用于表单的验证,模板渲染的功能基本不再使用。

2.为什么要表单数据验证

其实前端也是可以进行数据验证,但由于前后端分离的原因,还是在后端进一步验证可以保证传入到的数据合法。

3.安装

pip install wtforms-tornado

4.使用方式

  1. 创建表单类
    1. 需要继承wtforms_tornado.Form
    2. 定义字段类型
    - 可以使用wtforms.fields引入
    3. 定义验证规则
    - 可以使用wtforms.validators引入
  2. 创建表单对象
  3. 调用表单验证方法

5.Tornado_wtform数据验证

这里将使用原先的写过的个人信息填写,对其进行添加数据验证功能
个人信息案例原网址

5.1错误信息解决:

ImportError: cannot import name ‘compat’ from ‘wtforms’

  1. wtforms===3.0.1 删除 pip uninstall wtforms
  2. 下载旧版本pip install wtforms==2.3.3

5.2代码展示

from wtforms34 import UserForm# 建立表单对象uf = UserForm(self.request.arguments)# 验证if not uf.validate():# 成功:true 失败:falseimport jsondata = json.dumps(uf.errors, ensure_ascii=False)self.write(data)

表单验证规则:

from wtforms_tornado import Form
from wtforms.fields import IntegerField, StringField
from wtforms.validators import DataRequired, Length# 创建一个表单类
class UserForm(Form):# 定义字段:注意 验证字段的名字一定要和前端传递来的名字保持一致# 编写规则id = IntegerField('ID')username = StringField('用户名',validators=(DataRequired(message='请填写用户名'),Length(min=3,max=10,message='请输入3-10位的用户名')))nick_name = StringField('昵称')email = StringField('邮箱')password = StringField('密码')phone = StringField('电话')language = StringField('语言')

6.完整代码

from tornado.web import Application, RequestHandler, URLSpec
from tornado.ioloop import IOLoop
import asyncio
import aiomysql
# 引入
from wtforms34 import UserFormclass IndexHandle(RequestHandler):# 首先由Application创建路由地址时,携带参数传递会到initialize,去定义一个self.mysql用于get中获取参数def initialize(self,mysql):self.mysql = mysqlasync def get(self):print(self.mysql)# 获取1个客户端链接池async with aiomysql.create_pool(host=self.mysql.get('host'),port=self.mysql.get('port'),user=self.mysql.get('user'),password=self.mysql.get('pwd'),db=self.mysql.get('db')) as pool:# 获取1个链接,用来获取游标async with pool.acquire() as con:# 获取一个游标,用来操作数据库async with con.cursor() as cur:# 执行sql# sql = 'select 101'sql = 'select * from t_user'await cur.execute(sql)# 获取结果rs = await cur.fetchone()print(rs)self.render('personal34.html',user = rs)async def post(self):# 获取前端传递来的数据uname = self.get_argument('username')nick_name = self.get_body_argument('nick_name')email = self.get_argument('email')password = self.get_body_argument('password')phone = self.get_argument('phone')language = self.get_body_argument('language')# 建立表单对象uf = UserForm(self.request.arguments)# 验证if not uf.validate():# 成功:true 失败:falseimport jsondata = json.dumps(uf.errors, ensure_ascii=False)self.write(data)else:try:# 获取idid = self.get_body_argument('id')except Exception as e:id = Falseargs = [uname,nick_name,email,password,phone,language]# 链接数据库# 获取1个客户端链接池async with aiomysql.create_pool(host=self.mysql.get('host'),port=self.mysql.get('port'),user=self.mysql.get('user'),password=self.mysql.get('pwd'),db=self.mysql.get('db')) as pool:# 获取1个链接,用来获取游标async with pool.acquire() as con:# 获取一个游标,用来操作数据库async with con.cursor() as cur:if not id:sql = 'insert into t_user values(0, %s, %s, %s, %s, %s, %s)'await cur.execute(sql, args) # 提交事务await con.commit()# 获取生成的idid = cur.lastrowidelse:sql = 'update t_user set uname=%s, nick_name=%s, email=%s, pwd=%s, phone=%s, language=%s where id=%s'# 增加id来告诉数据库更新哪一条数据args.append(id)await cur.execute(sql, args)await con.commit()# 存放id到args中args.insert(0,id)self.render('personal34.html', user = args)if __name__ == '__main__':import os# 获取绝对路径base_path = os.path.abspath(os.path.dirname(__file__))# 设置应用参数settings = {'template_path':os.path.join(base_path, 'templates'),'static_path': os.path.join(base_path, 'static'),'static_url_prefix': '/static/','debug': True,# 为了方便数据库的修改,可以直接把参数单独放在这'mysql': {'host': '127.0.0.1','port': 3306,'user': 'root','pwd': 'root','db': 'tornado_db'}}# 创建Tornado应用app = Application([URLSpec('/',IndexHandle, {'mysql':settings.get('mysql')})], **settings)# 设置监听端口号app.listen(8000)IOLoop.current().start()'''
错误信息解决:
ImportError: cannot import name 'compat' from 'wtforms'wtforms===3.0.1 删除 pip uninstall wtforms下载旧版本pip install wtforms==2.3.3
'''
http://www.yayakq.cn/news/172825/

相关文章:

  • 个人备案之后用于商城网站微网站建设哪里便宜
  • 申请网站价格企业网站设计要点
  • 如何优化网站内容什么是垂直型网站
  • 做设计的一般在什么网站找素材dw旅游网站模板下载
  • 做个什么样的网站北京到安阳高铁时刻表
  • 无锡市城乡建设局网站wordpress windows 10
  • 站长之家工具查询南京做网站引流的公司
  • 网站为什么要续费网站服务器大小
  • 开奖网站开发在深圳找工作哪个网站好
  • 惠州网站建设推广wordpress侧栏插件
  • 郧阳网站建设东莞网站建设哪里找
  • 长宁区网站建设设计苏州做公司网站设计的公司
  • 网站开发业务ppt做的网站怎么转成网址链接
  • 十堰公司做网站asp网站源码免费下载
  • 网站主机服务器网站开发找谁
  • 怎么在百度建立公司网站没有网站也可以做cpa
  • 中州建设有限公司网站深圳龙华区高风险区域
  • 宠物网站建设论文crm订单管理系统免费
  • 网站开发的开题报告引言wordpress主题 移动
  • 360网站推广网站建设 网站内容 采集
  • dw网站怎么做点击图片放大火车票网站建设多少
  • 网站上的美工图片要怎么做佛山最新通知今天
  • 网站报错404图片网站cms
  • 网站建设广州网站建设开发网站报价方案
  • 枣庄做网站公司wordpress 判断手机版
  • 建设网站费用要进固定资产吗科技强国从升级镜头开始
  • 电子商务网站建设与综合实践网络营销的概念和特征
  • 团购网站建设怎么样网站建设服务器的配置
  • 商城网站的seo优化改怎么做网站一级域名
  • 嘉兴的信息公司网站黄骅市职教中心