必会的小细节知识点:
在局域网中让其他电脑访问我的网站:
如果想在同一个局域网下的其他电脑访问自己电脑上的Flask网站,
那么可以设置host='0.0.0.0'
才能访问得到。
指定端口号:
Flask项目,默认使用5000
端口。如果想更换端口,那么可以设置port=9000
。
url唯一:
在定义url的时候,一定要记得在最后加一个斜杠。
- 如果不加斜杠,那么在浏览器中访问这个url的时候,如果最后加了斜杠,那么就访问不到。这样用户体验不太好。
- 搜索引擎会将不加斜杠的和加斜杠的视为两个不同的url。而其实加和不加斜杠的都是同一个url,那么就会给搜索引擎造成一个误解。加了斜杠,就不会出现没有斜杠的情况。
GET
请求和POST
请求:
在网络请求中有许多请求方式,比如:GET、POST、DELETE、PUT请求等。那么最常用的就是GET
和POST
请求了。
-
GET
请求:只会在服务器上获取资源,不会更改服务器的状态。这种请求方式推荐使用GET
请求。 -
POST
请求:会给服务器提交一些数据或者文件。一般POST请求是会对服务器的状态产生影响,那么这种请求推荐使用POST请求。 -
关于参数传递:
GET
请求:把参数放到url
中,通过?xx=xxx
的形式传递的。因为会把参数放到url中,所以如果视力好,一眼就能看到你传递给服务器的参数。这样不太安全。POST
请求:把参数放到Form Data
中。会把参数放到Form Data
中,避免了被偷瞄的风险,但是如果别人想要偷看你的密码,那么其实可以通过抓包的形式。因为POST请求可以提交一些数据给服务器,比如可以发送文件,那么这就增加了很大的风险。所以POST请求,对于那些有经验的黑客来讲,其实是更不安全的。
-
在
Flask
中,route
方法,默认将只能使用GET
的方式请求这个url,如果想要设置自己的请求方式,那么应该传递一个methods
参数。
放个入门demo
from flask import Flask, url_for
app = Flask(__name__)
#1. 规定模板和静态文件的查找路径
#2. 以后一些flassk插件如果报错了,Flask可以通过name找到具体位置
# app.config.from_pyfile('config.py', silent=True)
@app.route('/')
def hello_world():
print(url_for('my_list', page=55, others=2))
# /list/55/
# return 'Hello 上岁数odfsdsdfrld!'
return url_for('my_list', page=44, others=3)
@app.route('/aa/<art_id>/')
def art_detail(art_id):
return '%s' % art_id
@app.route('/list/<page>/')
def my_list(page):
return 'my_list'
if __name__ == '__main__':
app.run(debug=True)
URL与视图函数的映射:
传递参数:
传递参数的语法是:/<参数名>/
。然后在视图函数中,也要定义同名的参数。
参数的数据类型:
- 如果没有指定具体的数据类型,那么默认就是使用
string
数据类型。 int
数据类型只能传递int
类型。float
数据类型只能传递float
类型。path
数据类型和string
有点类似,都是可以接收任意的字符串,但是path
可以接收路径,也就是说可以包含斜杠。uuid
数据类型只能接收符合uuid
的字符串。uuid
是一个全宇宙都唯一的字符串,一般可以用来作为表的主键。any
数据类型可以在一个url
中指定多个路径,例如:@app.route('/<any(blog,article):url_path>/<id>/') def detail(url_path,id): if url_path == 'blog': return '博客详情:%s' % id else: return '博客详情:%s' % id
接收用户传递的参数:
- 第一种:使用path的形式(将参数嵌入到路径中),就是上面讲的。
- 第二种:使用查询字符串的方式,就是通过
?key=value
的形式传递的。@app.route('/d/') def d(): wd = request.args.get('wd') return '您通过查询字符串的方式传递的参数是:%s' % wd
- 如果你的这个页面的想要做
SEO
优化,就是被搜索引擎搜索到,那么推荐使用第一种形式(path的形式)。如果不在乎搜索引擎优化,那么就可以使用第二种(查询字符串的形式)。