Flask基本使用
上下文
-
程序上下文
current_app
g
-
请求上下文
request
session
https://blog.****.net/wsxqaz/article/details/9083093
请求前后处理
before_first_request:注册一个函数,在处理第一个请求之前运行。
before_request:注册一个函数,在每次请求之前运行。
after_request:注册一个函数,如果没有未处理的异常抛出,在每次请求之后运行。
teardown_request:注册一个函数,即使有未处理的异常抛出,也在每次请求之后运行。
在请求钩子函数和视图函数之间共享数据一般使用上下文全局变量 g 。例如,before_request 处理程序可以从数据库中加载已登录用户,并将其保存到 g.user 中。随后调用视图函数时,视图函数再使用 g.user 获取用户。
视图函数响应
视图函数返回的响应还可接受三个参数:
return '<h1>Bad Request</h1>',400,由首部(header)组成的字典
Flask 视图函数还可以返回 Response对象:
@app.route('/')
def index():
user_agent = request.headers.get('User-Agent')
# return '<h1>you brower is %s</h1>' % user_agent,400
response = make_response('<h1>This document carries a cookie!<h1>')
response.set_cookie('answer', '42')
return response
werkzeug
是一个WSGI的Python库:http://werkzeug.pocoo.org/
Flask扩展
命令行解析器,支持使用命令行参数形式对flask进行扩展:flask-script
from flask import Flask
from flask_script import Manager
app = Flask(__name__)
manager=Manager(app)
if __name__ == '__main__':
# app.run(debug=True)
manager.run()
Flask中Blueprint
http://flask.pocoo.org/docs/0.12/blueprints/
Jinja2
api:http://jinja.pocoo.org/docs/2.10/templates/
Jinja2 还支持宏。宏类似于 Python 代码中的函数。
集成Bootstrap,pip install flask-bootstrap
如果要在衍生模板中添加新的 JavaScript 文件,需要这么定义 scripts 块:
{% block scripts %}
{{ super() }}
<script type="text/javascript" src="my-script.js"></script>
{% endblock %}
urlfor() 函数最简单的用法是以视图函数名(或app.addurl_route() 定义路由时使用的端点名)作为参数,返回对应的 URL。例如,在当前版本的 hello.py 程序中调用 urlfor('index') 得到的结果是 / 。调用 urlfor('index', _external=True) 返回的则是绝对地 址,在这个示例中是 http://localhost:5000/。
Flask-Moment本地化日期和时间
web表单
http://www.pythondoc.com/flask-wtf/
pip install flask-wtf
Flask程序中支持MarkDown
https://pythonhosted.org/Flask-Markdown/
pip install flask-Markdown
Flask程序中发送邮件
https://pythonhosted.org/Flask-Mail/
pip install flask-mail
数据库
http://www.pythondoc.com/flask-sqlalchemy/quickstart.html
pip install flask-sqlalchemy
sqlalchemy就是一个ORM框架,本身无法操作数据库,其必须以来pymsql等第三方插件。
配置如下(按照教程中配置会报错的,必须配合三方插件):
app.config['SQLALCHEMY_DATABASE_URI'] ='mysql+pymysql://username:password@hostname/database'
- 使用Flask-Migrate实现数据库迁移
- https://flask-migrate.readthedocs.io/en/latest/
仅当数据库表不存在时,Flask-SQLAlchemy 才会根据模型进行创建。因此,更新表的唯一方式就是先删除旧表,不过这样做会丢失数据库中的所有数据。更新表的更好方法是使用数据库迁移框架。源码版本控制工具可以跟踪源码文件的变化,类似地,数据库迁移框架能跟踪数据库模式的变化,然后增量式的把变化应用到数据库中。
# 创建迁移仓库
python hello.py db init
# 自动创建迁移脚本(其实就是对比模型和数据表自动生成差异版本)
python manage.py db migrate -m "initial migration"
# 执行升级
python manage.py db upgrade
会话管理
为 Flask 提供了用户会话管理。它处理了日常的登入,登出并且长时间记住用户的会话。
http://www.pythondoc.com/flask-login/
pip install flask-login
认证
使用 flask_httpauth 扩展实现认证授权。
https://flask-httpauth.readthedocs.io/en/latest/
pip install flask-httpauth
生成确认令牌的包
https://itsdangerous.readthedocs.io/en/1.1.x/
pip install itsdangerous
单元测试:unittest
https://docs.python.org/3.5/library/unittest.html
Restful Api接口测试:httpie
https://httpie.org/doc
代码覆盖工具
pip install coverage
使用Selenium进行端到端测试
pip install selenium
报告缓慢的数据库查询
from flask.ext.sqlalchemy import getdebugqueries
监视资源消耗
分析器监视运行中的程序,记录调用的函数以及运行各函数 所消耗的时间,然后生成一份详细的报告。
@manager.command
def profile(length=25, profile_dir=None):
"""Start the application under the code profiler."""
from werkzeug.contrib.profiler import ProfilerMiddleware
app.wsgi_app = ProfilerMiddleware(app.wsgi_app, restrictions=[length],
profile_dir=profile_dir)
app.run()
部署
- uwsgi
- nginx
部署过程中的问题:
=========1==========
错误a duplicate default server for 0.0.0.0:80
删除/etc/nginx/sites-available/default文件,重新启动服务即可
==========2==========
解决“upstream prematurely closed connection”报错
https://www.centos.bz/2018/01/nginxuwsgi%E5%AE%8C%E7%BE%8E%E9%85%8D%E7%BD%AE%E6%96%87%E4%BB%B6%EF%BC%8C%E8%A7%A3%E5%86%B3upstream-prematurely-closed-connection%E6%8A%A5%E9%94%99/
==========3(当然使用root不是好的方式,这里只是测试)===========
vim /etc/nginx/nginx.conf
# user www-data;
user root;
https://www.weiweiblog.cn/nginx-13-permission-denied/
nginx 加载各配置conf
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
访问 502 Bad Gateway,后来查看日志发现是
-- unavailable modifier requested: 0 --
参考:
https://blog.flytrap.top/2018/03/09/tech/linux/deploy/unavailablemodifierrequested/
启动mysql:
docker ps -a 找到mysql镜像
docker start 容器id
进入到flasky的发布目录:
启动uwsgi
uwsgi --plugin python3 config.ini -d ./logs/flask.log
检查是否成功:ps aux | grep uwsgi
servic nginx start
使用Flask-SSLify启用安全HTTP
其它扩展
- Flask-Babel(https://pythonhosted.org/Flask-Babel/):提供国际化和本地化支持。
- FLask-RESTful(http://flask-restful.readthedocs.org/en/latest/):开发 REST API 的工具。
- Celery(http://docs.celeryproject.org/en/latest/):处理后台作业的任务队列。
- Frozen-Flask(https://pythonhosted.org/Frozen-Flask/):把 Flask 程序转换成静态网站。
- Flask-DebugToolbar(https://github.com/mgood/flask-debugtoolbar):在浏览器中使用的 调试工具。
- Flask-Assets(https://github.com/miracle2k/flask-assets):用于合并、压缩、编译 CSS 和 JavaScript 静态资源文件。
- Flask-OAuth(http://pythonhosted.org/Flask-OAuth/):使用 OAuth 服务进行认证。
- Flask-OpenID(http://pythonhosted.org/Flask-OpenID/):使用 OpenID 服务进行认证。
- Flask-WhooshAlchemy(https://pythonhosted.org/Flask-WhooshAlchemy/):使用 Whoosh , (http://pythonhosted.org/Whoosh/)实现 Flask-SQLAlchemy 模型的全文搜索。
- Flask-KVsession(http://flask-kvsession.readthedocs.org/en/latest/):使用服务器端存储实现的另一种用户会话
代码:https://github.com/tianbogit/flasky
部署地址:http://www.51wxzs.cn/