1.安装
pip install Flask
2.从hello world开始
# coding=utf-8
from flask import Flask
app=Flask(__name__)
@app.route('/')
def hello_world():
return 'hello world!'
if __name__ == '__main__':
app.run(host='0.0.0.0', port=9000)
3.配置管理
(1)通过config类添加配置信息
app=Flask(__name__)
app.config['DEBUG']=True
app.config是flask.config.Config类的实例,继承内置结构dict
(2)导入配置文件方法
1. 模块对象导入
import settings
app.config.from_object(settings)
2.通过文件名字加载
app.config.from_pyfile('settings.py',silent=True)
默认当配置文件不存在时会抛出异常,使用silent=True的时候只是返 回False,但不会 抛出异常
3.通过环境变量加载。这种方式依然支持silent,获得路径后其实还是使用from_pyfile的方式加载
app.config.from_envvar('SETTINGS')
4.调试模式,开启可自动加载代码
(1)直接在应用对象上设置
app.debug=True
app.run()
(2)作为run的参数传入
app.run(debug=True)
(3)werkzeug-0.11 PIN码身份验证,在调试模式下使用,可保护调试环境。默认启动会分配pin code,当程序异常时浏览器会弹出要求输入PIN值的输入框。也可指定PIN码的值。
WERKZEUG_DEBUG_PIN=123 python debug.py
5.动态URL规则
(1)指定自路径
@app.route('/item/<id>/')
def item(id):
return 'Item:{}'.format(id)
尖括号中的内容是动态的,凡是匹配到/item前缀的URL都被映射到这个路由上,在内部id作为参数获取。未指定时<variable_name>,默认类型为字符串。如需指定可标记为<converter:variable_name>格式。可接受类型有:string(不接受斜杠)、 int、 float、 path(接受斜杠)、 uuid、any(可指定多种路径,但需要参入参数。
@app.route('/<any(a,b):page_name>/')
访问/a/和访问/b/都符合这个规则,/a/对应的page_name就是a
(2)不定制子路径
/computer/?name=macbook这样就可通过request.args.get('name')获取name值。如使用POST方法,表单参数通过request.form.get('name')获得
6.自定义URL转换器
通过继承werkzeug.routing.BaseConverter类,重写父类中的init(),to_python(),to_url()方法
7.HTTP方法
(1)HTTP有多个访问URL方法,默认情况下,路由只回应GET请求,但是通过app.route装饰器传递methods参数可以改变这个行为:
@app.route('/login', methods=['GET','POST'])
@app.route('/j/item/<id>', methods=['DELETE', 'POST'])
(2)HTTP方法和使用场景。
GET:获取资源,GET操作应该是幂等的。
HEAD:想要获取信息,但是只关心消息头。应用应该像处理GET请求一样来处理它,但是不返回实际内容。
POST:创建一个新的资源。
PUT:完整地替换资源或者创建资源。PUT操作虽然有副作用,但应该是幂等的。
DELETE:删除资源。DELETE操作有副作用,但也是幂等的。
OPTIONS:获取资源支持的所有HTTP方法。
PATCH:局部更新,修改某个已有的资源。
注:幂等表示在相同的数据和参数下,执行一次或多次产生的效果是一样的。