最近比较忙

快速玩Flask框架,为微博做些准备

part 1 python程序
  1. from flask importFlask, render_template, session, redirect, url_for, flash
  2. from flask_bootstrap importBootstrap
  3. from flask_moment importMoment
  4. from datetime import datetime
  5. from flask_wtf importForm
  6. from wtforms importStringField,SubmitField
  7. from wtforms.validators importRequired
  8. from flask_sqlalchemy importSQLAlchemy
  9. from flask_script importManager
  10. import os
  11. basedir = os.path.abspath(os.path.dirname(__file__))
  12. app =Flask(__name__)
  13. #wtf表单验证
  14. app.config['SECRET_KEY']='hard to guess string'
  15. #数据库URL
  16. app.config['SQLALCHEMY_DATABASE_URI']= \
  17. 'sqlite:///'+ os.path.join(basedir,'data.sqlite')
  18. #每次请求结束后自动提交数据变动
  19. app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN']=True
  20. bootstrap =Bootstrap(app)
  21. moment =Moment(app)
  22. db =SQLAlchemy(app)
  23. manager =Manager(app)
  24. #wtf表单类
  25. classNameForm(Form):
  26. name =StringField('What is your name?', validators=[Required()])
  27. submit =SubmitField('Submit')
  28. #数据库中的table类
  29. classRole(db.Model):
  30. __tablename__ ='roles'
  31. id = db.Column(db.Integer, primary_key=True)
  32. name = db.Column(db.String(64), unique=True)
  33. users = db.relationship('User', backref='role', lazy='dynamic')
  34. def __repr__(self):
  35. return'<Role %r>'% self.name
  36. classUser(db.Model):
  37. __tablename__ ='users'
  38. id = db.Column(db.Integer, primary_key=True)
  39. username = db.Column(db.String(64), unique=True, index=True)
  40. role_id = db.Column(db.Integer, db.ForeignKey('roles.id'))
  41. def __repr__(self):
  42. return'<User %r>'% self.username
  43. #主页
  44. @app.route('/', methods=['GET','POST'])
  45. def index():
  46. form =NameForm()
  47. if form.validate_on_submit():
  48. user =User.query.filter_by(username=form.name.data).first()
  49. if user isNone:
  50. user =User(username=form.name.data)
  51. db.session.add(user)
  52. session['known']=False
  53. else:
  54. session['known']=True
  55. session['name']= form.name.data
  56. form.name.data =''
  57. return redirect(url_for('index'))
  58. return render_template('user.html', form=form, name=session.get('name'), known=session.get('known',False),
  59. current_time=datetime.utcnow())
  60. #404页
  61. @app.errorhandler(404)
  62. def page_not_found(e):
  63. return render_template('404.html'),404
  64. #500页
  65. @app.errorhandler(500)
  66. def internal_server_error(e):
  67. return render_template('500.html'),500
  68. #manager.run() 用于是服务器在命令行运行
  69. if __name__ =='__main__':
  70. app.run(debug=True)
  71. # manager.run()
part 2 基模板
主页面:
  1. <!-- 基于bootstrap/base.html的基模板 默认有导航栏 page——content可重写-->
  2. {% extends "bootstrap/base.html" %}
  3. <!-- 导入moment.js -->
  4. {% block scripts %}
  5. {{ super() }}
  6. {{ moment.include_moment() }}
  7. {% endblock %}
  8. {% block title %}Flasky{% endblock %}
  9. {% block head %}
  10. {{ super() }}
  11. <linkrel="shortcut icon"href="{{ url_for('static', filename = 'favicon.ico') }}"
  12. type="image/x-icon">
  13. <linkrel="icon"href="{{ url_for('static', filename = 'favicon.ico') }}"
  14. type="image/x-icon">
  15. {% endblock %}
  16. {% block navbar %}
  17. <divclass="navbar navbar-inverse"role="navigation">
  18. <divclass="container">
  19. <divclass="navbar-header">
  20. <buttontype="button"class="navbar-toggle"
  21. data-toggle="collapse"data-target=".navbar-collapse">
  22. <spanclass="sr-only">Toggle navigation</span>
  23. <spanclass="icon-bar"></span>
  24. <spanclass="icon-bar"></span>
  25. <spanclass="icon-bar"></span>
  26. </button>
  27. <aclass="navbar-brand"href="/">Flasky</a>
  28. </div>
  29. <divclass="navbar-collapse collapse">
  30. <ulclass="nav navbar-nav">
  31. <li><ahref="/">Home</a></li>
  32. </ul>
  33. </div>
  34. </div>
  35. </div>
  36. {% endblock %}
  37. {% block content %}
  38. <!-- 弹出警告信息-->
  39. <divclass="container">
  40. {% for message in get_flashed_messages() %}
  41. <divclass="alert alert-warning">
  42. <buttontype="button"class="close"data-dismiss="alert">×</button>
  43. {{ message }}
  44. </div>
  45. {% endfor %}
  46. {% block page_content %}{% endblock %}
  47. </div>
  48. {% endblock %}
自定义错误页面:
  1. <!DOCTYPE html>
  2. {% extends "base.html" %}
  3. {% block title %}Flasky - Page Not Found{% endblock %}
  4. {% block page_content %}
  5. <divclass="page-header">
  6. <h1>Not Found</h1>
  7. </div>
  8. {% endblock %}
 

【Flask】Flask快速玩框架的更多相关文章

  1. python三大web框架Django,Flask,Flask,Python几种主流框架,13个Python web框架比较,2018年Python web五大主流框架

    Python几种主流框架 从GitHub中整理出的15个最受欢迎的Python开源框架.这些框架包括事件I/O,OLAP,Web开发,高性能网络通信,测试,爬虫等. Django: Python We ...

  2. 初识Flask、快速启动

    目录 一.初识Flask 1.1 什么是flask? 1.2 为什么要有flask? 二.Flask快速启动 一.初识Flask 1.1 什么是flask? Flask 本是作者 Armin Rona ...

  3. python操作三大主流数据库(4)python操作mysql④python服务端flask和前端bootstrap框架结合实现新闻展示

    python操作mysql④python服务端flask和前端bootstrap框架结合实现新闻展示 参考文档http://flask.pocoo.org/docs/0.11/http://flask ...

  4. 仿flask写的web框架

    某大佬仿flask写的web框架 web_frame.py from werkzeug.local import LocalStack, LocalProxy def get_request_cont ...

  5. Flask 安装 快速入门

    $ pip install flask Flask自带的Server在端口5000上监听: ython app.py flask通过request.form['name']来获取表单的内容. 外部可见 ...

  6. Inside Flask - Flask 简介

    Inside Flask - Flask 简介 前言 Flask 的设计目标是实现一个 wsgi 的微框架,其核心代码保持简单和可扩展性,很容易学习.对于有一定经验初学者而言,跟着例子和一些书的代码来 ...

  7. Inside Flask - flask.__init__.py 和核心组件

    Inside Flask - flask.__init__.py 和核心组件 简单的示例 首先看看一个简单的示例.使用 Flask ,通常是从 flask 模块导入 Flask . request 等 ...

  8. 快速玩转Apple Pay开发

    快速玩转Apple Pay开发 更新时间:2016年02月20日09时25分 来源:传智播客 Apple Pay 2016年2月18日上午,苹果公司宣布,与中国银联达成合作,正式在中国大陆上线Appl ...

  9. day92:flask:flask简介&基本运行&路由&HTTP请求和响应

    目录 1.Flask简介 2.关于使用flask之前的准备 3.flask的基本运行 4.flask加载配置 5.传递路由参数(没有限定类型) 6.传递路由参数(通过路由转换器限定路由参数的类型) 7 ...

随机推荐

  1. SQL&&LINQ:左(外)连接,右(外)连接,内连接,完全连接,交叉连接,多对多连接

    SQL: 外连接和内连接: 左连接或左外连接:包含左边的表的所有行,如果右边表中的某行没有匹配,该行内容为空(NULL) --outer jion:left join or left outer jo ...

  2. console打印数组object具体内容

    例如 var data=[ {}, {}, {} ] 需要打印出以上data中每个{}内容,可以使用如下方式: for(var i=0;i<data.length;i++) { var a = ...

  3. Intellij 图标介绍及配置文件常识

    图标 参数名称   含义 默认值   -Xms 初始堆大小 物理内存的1/64(<1GB) 默认(MinHeapFreeRatio参数可以调整)空余堆内存小于40%时,JVM就会增大堆直到-Xm ...

  4. Vim入门教程

    尽管网上有成打的Vim在线教程,但是要么艰深晦涩,要么太过肤浅.本教程的目标让每个阶段都有斩获,从理解它的哲学(将和你终身相伴)到超越现在编辑技巧,成为其中的牛人. 简单来说,本教程的学习方式将使你终 ...

  5. php 判断是手机版还是电脑端

    function isMobile() { // 如果有HTTP_X_WAP_PROFILE则一定是移动设备 if (isset ($_SERVER['HTTP_X_WAP_PROFILE'])) { ...

  6. MultiDex到底有多坑

    google为什么要引入MultiDex? dex指令是用16位寄存器来保存dex中的方法数,所以限制了在apk 中最大的方法数为65535,当超过这个最大值在编译的时候会报 方法数超标的错误. 如何 ...

  7. CSS3中的Transition属性详解

    w3c标准中对CSS3的transition这是样描述的:“CSS的transition允许CSS的属性值在一定的时间区间内平滑地过渡.这种效果可以在鼠标单击.获得焦点.被点击或对元素任何改变中触发, ...

  8. MySQL学习笔记--基本操作

    1.登录数据库 在命令行输入 "mysql -u username -p" 回车后输入密码 2.选择数据库 USE datebase name,选择要操作的数据库 3.显示所有数据 ...

  9. SourceForge无法访问的解决办法

    这一阵java框架spring和hibernate都有新版本了(spring2.5.5和hibernate3.2.6)想下载看看,却发现 SourceForge.net无法打开.刚才用Google搜索 ...

  10. 编程之美--2. Trie树 (Trie图)

    #1014 : Trie树 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相帮助, ...