何为路由?
顾名思义就是一条路径,这条路引领 url 从浏览器到WSGI服务器,然后将处理结果返回到Browser。在 Flask 框架中 ,路由的作用就是为用户请求的URL找出其对应的处理函数 。
1. 注册路由
Flask 框架中: 根据HTTP请求的URL在路由表中寻找对应的URL规则,找到对应的视图函数,并将视图函数的执行结果返回给WSGI服务器。注:Flask封装了一个简单的开发用的WSGI服务器,调用run函数时,该服务器启动。
其实,在Flask里边有一个中转的机制---------endpoint
在Flask内部使用两张表维护路由:
url_map:维护URL规则和endpoint的映射
view_functions:维护endpoint和视图函数的映射。
默认访问点 :当我们使用route装饰器注册路由时,默认使用被装饰函数的 函数名(name)作为访问点。
自定义访问点 :可以在使用route装饰器或调用add_url_rule()方法注册路由时,使用 endpoint关键字参数改变这一默认行为。
@app.route('/test',endpoint='self_define')
def test():pass
2. 两种路由方式
① 调用 add_url_route() 为函数指定一个路由
def test():
return 'this is test'
app.add_url_route('/test',view_func=test)
② 用 route 装饰器将一个url规则绑定到一个视图函数上
@app.route('/test')
def test():
return 'this is test'
显然, 使用装饰器让代码看起来更加的简洁明了
3. 动态路由
要给 URL 添加变量部分,你可以把这些特殊的字段标记为 <variable_name> , 这个部分将会作为命名参数传递到你的函数。规则可以用 <converter:variable_name> 指定一个可选的转换器
@app.route('/user/<username>')
def show_user_profile(username):
# show the user profile for that user
return 'User %s' % username
@app.route('/post/<int:post_id>')
def show_post(post_id):
# show the post with the given id, the id is an integer
return 'Post %d' % post_id
转换器有下面几种:
int 接受整数
float 接受浮点数
path 和默认的相似,但接受斜线
这里解释一下
假如我们要访问四个文件,目录结构如上图所示
@app.route('/file/<fname>')
def v_file(fname):
fullname = os.path.join('/A/B',fname)
f = open(fullname)
content = f.read()
f.close()
return cnt
测试结果表明,/file/a.txt和/file/b.txt都没有问题,但是/file/C/c.txt和 /file/C/d.txt却会失败。
这是因为,默认情况下,在URL规则中的变量被视为不包含/的字符串。/file/C/c.txt 是没有办法匹配URL规则/file/的。
如果这里改为path,则四个文件都可以访问到
@app.route('/file/<path:fname>')
def v_file(fname):
fullname = os.path.join('/A/B',fname)
f = open(fullname)
content = f.read()
f.close()
return cnt
4. 添加HTTP方法
HTTP有许多不同的访问 URL 方法。默认情况下,路由只回应 GET 请求,但是通过 route() 装饰器传递 methods 参数可以改变这个行为。例如:
@app.route('/login', methods=['GET', 'POST'])
def login():
if request.method == 'POST':
do_the_login()
else:
show_the_login_form()
5. 静态目录路由
当创建应用实例时,Flask将自动添加一条静态目录路由,其访问点 始终被设置为static,URL规则默认被设置为/static,本地路径默认被 设置为应用文件夹下的static子文件夹
改变默认的本地路径 :可以在创建应用对象时使用关键字参数static_folder改变 默认的静态文件夹。例如,你的静态文件都存放在应用下的assets目录下, 那么可以按如下的方式创建应用对象:
app = Flask(name,static_folder='assets')
6. url_for函数
url_for() 函数最简单的用法是以视图函数名(或者app.add_url_route() 定义路由时使用的端点名)作为参数,返回对应的URL。例如,在当前程序中调用url_for('index') 得到的结果是/。调用url_for('index', _external=True) 返回的则是绝对地址,在这个示例中是http://localhost:5000/
参数分别是 视图函数 、变量、参数
print url_for('A',name='B',format='c')
输出
A/B?format=c
下面这个使用_anchor关键字可以为生成的URL添加锚点
print url_for('A',_anchor='d')
输出
/A#d
使用 render_template() 方法来渲染模板。Flask 会在 templates 文件夹里寻找模板。
@main.route('/', methods=['GET', 'POST'])
def index():
return render_template('main/index.html')
这里不再细讲,url_for函数有其他功能,
1. 传入url_for() 的关键字参数不仅限于动态路由中的参数。函数能将任何额外参数添加到查询字符串中。例如,url_for('index', page=2) 的返回结果是/?page=2。
2 通过 路由.视图函数 可以定位到其他界面,例如
<a href="{{ url_for('main.index') }}">首页</a>