用户个人资料页面
要创建一个用户个人资料页面,首先编写一个映射到 /user/<username>URL
的新视图函数。
这个由@app.route装饰器下声明的视图函数看起来与前面的有点不同。在这个示例下,有一个动态组件,它被作为<username>
URL组件 表示,并由 <
和>
包围。当路由有动态组件时,Flask将接受URL部分中的任何文本,并将以实际文本作为参数调用视图函数。例如,如果客户端浏览器请求这个URL /user/susan
,则将调用视图函数并将参数username
设置为susan
。这个视图函数只能由登录用户访问,因此添加了Flask-Login的@login_required
装饰器
这个视图函数的实现非常简单。首先,尝试用username
查询从数据库加载用户。在之前学过,假如想获得所有结果,可调用all()
执行数据库查询;假如想获得第一个结果 或None
(0个结果时),可调用first()
执行数据库查询。在这个视图函数中,使用了一个叫first_or_404()
的first()
变体,在有结果的情况下它与first()
完全一样,不过在没有结果的情况下,会自动将404 error
发送回客户端。以这种方式执行查询,不用检查查询是否返回一个用户,因为数据库中不存在username
时,函数将不会返回,而是会引发404异常
。
如果数据库查询没有触发404 error
,那么表示找到给定username
的用户。接下来, 为用户初始化一个“假”的帖子列表,最后渲染一个新的user.html模板&