Flask-URL管理

动态URL规则

URL规则可以添加变量部分,也就是将符合同种规则的URL抽象成一个URL模式,如“/item/1/”,“/item2/”,假如不抽象,我们就得这样写:

@app.route("/item/1/")

动态URL写法:

@app.route("/item1/<id>/")
def item1(id):
    pass

尖括号的内容是动态的,凡是匹配到的/item/前缀的URL都会被映射到这个路由上,在内部把id作为参数而获得。它使用了特殊的字段标记,默认类型是字符串。如果需要制定参数类型需要标记成这样的格式,converter有下面几种:

  • string:接收任何没有斜杠”/”的文本(默认)
  • int:接收整数
  • float:同int,但是接收浮点数
  • path:和默认的相似,但也接收斜杠
  • uuid:只接受uuid字符串
  • any:可以指定多种路径,但是需要传入参数
@app.route("/any(a,b):page_info")
def page_info(page_info):
    pass

访问/a/和访问/b/都符合这个规则,如果不希望定制子路径,还可以通过传递参数的方式,例如:/item1?name=laowang。默认使用的是GET方法才能请求,开发者可以通过request.args.get(“name”)。如果需设定使用POST请求,在URL后面,添加methods=[“POST”],如app.route(“/item1”,methods=[“POST”]),开发者可以使用 request.form.get(‘name’)获得传入的name的值。

唯一URL

Flask的URL规则基于Werkzeug的路由模块。这个模块背后的思想是基于Apache以及更早的HTTP服务器的主张,希望保证优雅且唯一的URL。
举个栗子:

@app.route("/about/")
def about():
    ...

上述栗子像一个文件系统中的文件夹,访问一个结尾不带斜线的URL会被重定向到带斜线的规范的URL上去,这样也有助于避免搜索引擎引同一个页面两次.
再举个栗子:

@app.route("/about")
def about():
    ...

URL不带斜线,当用户访问带斜线的URL”/about/”会产生一个Not Found的错误。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flask-Login是一个Flask扩展,它提供了用户会话管理,包括登录、注销、记住会话等功能。在Flask应用程序中使用Flask-Login可以很容易地实现用户认证和授权。 关于Flask-Login的登录页面,一般来说,你需要创建一个登录表单,然后在视图函数中处理表单提交的数据。具体步骤如下: 1. 创建登录表单,可以使用Flask-WTF扩展来实现表单验证和CSRF保护。 2. 在视图函数中处理表单提交的数据,如果表单验证通过,则使用Flask-Login提供的login_user函数将用户登录状态保存到会话中。 3. 在模板中显示登录表单,并提供注销按钮。 下面是一个简单的示例代码: ```python from flask import Flask, render_template, redirect, url_for, request from flask_login import LoginManager, login_user, logout_user, login_required, UserMixin app = Flask(__name__) app.config['SECRET_KEY'] = 'your_secret_key_here' login_manager = LoginManager() login_manager.init_app(app) class User(UserMixin): def __init__(self, id): self.id = id @login_manager.user_loader def load_user(user_id): return User(user_id) @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': user_id = request.form['user_id'] password = request.form['password'] if user_id == 'admin' and password == 'password': user = User(user_id) login_user(user) return redirect(url_for('index')) else: return render_template('login.html', error='Invalid username or password') else: return render_template('login.html') @app.route('/logout') @login_required def logout(): logout_user() return redirect(url_for('index')) @app.route('/') @login_required def index(): return render_template('index.html') if __name__ == '__main__': app.run(debug=True) ``` 在这个示例中,我们创建了一个User类来表示用户,实现了一个load_user函数来根据用户ID加载用户对象。在登录视图函数中,我们处理表单提交的数据,如果验证通过,则使用login_user函数将用户登录状态保存到会话中。在注销视图函数中,我们使用logout_user函数将用户登录状态从会话中删除。在主页视图函数中,我们使用@login_required装饰器来保护需要登录才能访问的页面。 关于Flask-Login的更多信息,你可以参考官方文档:https://flask-login.readthedocs.io/en/latest/

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值