config 文件配置方式
### 使用`app.config.from_object`的方式加载配置文件:
#1. 导入`import config`。
#2. 使用`app.config.from_object(config)`。
### 使用`app.config.from_pyfile`的方式加载配置文件:
#这种方式不需要`import`,直接使用`app.config.from_pyfile('config.py')`就可以了。
#注意这个地方,必须要写文件的全名,后缀名不能少。
#1. 这种方式,加载配置文件,不局限于只能使用`py`文件,普通的`txt`文件同样也适合。
#2. 这种方式,可以传递`silent=True`,那么这个静态文件没有找到的时候,不会抛出异常。
# 传递`silent=False` 直接抛出异常
# URL与视图函数的映射:
### 传递参数:
传递参数的语法是:`/<参数名>/`。然后在视图函数中,也要定义同名的参数。
### 参数的数据类型:
1. 如果没有指定具体的数据类型,那么默认就是使用`string`数据类型。
2. `int`数据类型只能传递`int`类型。
3. `float`数据类型只能传递`float`类型。
4. `path`数据类型和`string`有点类似,都是可以接收任意的字符串,但是`path`可以接收路径,也就是说可以包含斜杠。
5. `uuid`数据类型只能接收符合`uuid`的字符串。`uuid`是一个全宇宙都唯一的字符串,一般可以用来作为表的主键。
6. `any`数据类型可以在一个`url`中指定多个路径。例如:
```python
@app.route('/<any(blog,article):url_path>/<id>/')
def detail(url_path,id):
if url_path == 'blog':
return '博客详情:%s' % id
else:
return '博客详情:%s' % id
```
### 接收用户传递的参数:
1. 第一种:使用path的形式(将参数嵌入到路径中),就是上面讲的。
2. 第二种:使用查询字符串的方式,就是通过`?key=value`的形式传递的。
```python
@app.route('/d/')
def d():
wd = request.args.get('wd')
return '您通过查询字符串的方式传递的参数是:%s' % wd
```
3. 如果你的这个页面的想要做`SEO`优化,就是被搜索引擎搜索到,那么推荐使用第一种形式(path的形式)。如果不在乎搜索引擎优化,那么就可以使用第二种(查询字符串的形式)。
### 自定义URL转换器的方式:
1. 实现一个类,继承自`BaseConverter`。
2. 在自定义的类中,重写`regex`,也就是这个变量的正则表达式。
3. 将自定义的类,映射到`app.url_map.converters`上。比如:
```python
app.url_map.converters['tel'] = TelephoneConverter
```
### `to_python`的作用:
这个方法的返回值,将会传递到view函数中作为参数。
### `to_url`的作用:
这个方法的返回值,将会在调用url_for函数的时候生成符合要求的URL形式。
### 重要知识点
# 必会的小细节知识点:
### 在局域网中让其他电脑访问我的网站:
如果想在同一个局域网下的其他电脑访问自己电脑上的Flask网站,
那么可以设置`host='0.0.0.0'`才能访问得到。
### 指定端口号:
Flask项目,默认使用`5000`端口。如果想更换端口,那么可以设置`port=9000`。
### url唯一:
在定义url的时候,一定要记得在最后加一个斜杠。
1. 如果不加斜杠,那么在浏览器中访问这个url的时候,如果最后加了斜杠,那么就访问不到。这样用户体验不太好。
2. 搜索引擎会将不加斜杠的和加斜杠的视为两个不同的url。而其实加和不加斜杠的都是同一个url,那么就会给搜索引擎造成一个误解。加了斜杠,就不会出现没有斜杠的情况。
### `GET`请求和`POST`请求:
在网络请求中有许多请求方式,比如:GET、POST、DELETE、PUT请求等。那么最常用的就是`GET`和`POST`请求了。
1. `GET`请求:只会在服务器上获取资源,不会更改服务器的状态。这种请求方式推荐使用`GET`请求。
2. `POST`请求:会给服务器提交一些数据或者文件。一般POST请求是会对服务器的状态产生影响,那么这种请求推荐使用POST请求。
3. 关于参数传递:
* `GET`请求:把参数放到`url`中,通过`?xx=xxx`的形式传递的。因为会把参数放到url中,所以如果视力好,一眼就能看到你传递给服务器的参数。这样不太安全。
* `POST`请求:把参数放到`Form Data`中。会把参数放到`Form Data`中,避免了被偷瞄的风险,但是如果别人想要偷看你的密码,那么其实可以通过抓包的形式。因为POST请求可以提交一些数据给服务器,比如可以发送文件,那么这就增加了很大的风险。所以POST请求,对于那些有经验的黑客来讲,其实是更不安全的。
4. 在`Flask`中,`route`方法,默认将只能使用`GET`的方式请求这个url,如果想要设置自己的请求方式,那么应该传递一个`methods`参数。
[Flask] Python Flask 框架(三)
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 一、模板简介 Jinja 模板的使用方法。 模板标签 其实Jinja 模板和其他语言和框架的模板类似,反正都是通...
- 接上文Python 通过 Flask 框架构建 REST API(二)——优化项目架构。前面介绍了如何通过 Fla...
- 注:本文所有代码均经过Python 3.7实际运行检验,保证其严谨性。 本文阅读时间约为2分钟。 本节课要介绍We...
- 很多同学在学习Pythonweb的时候都会遇到选择上的问题,是学习django,还是学习flask,还是学习Tor...
- 写在前面 这是我第一次尝试写博客,目的是跟广大的技术学习爱好者分享一些好玩的、实用的技术,同时也是对自己知识的一种...