Flask-Login扩展学习总结

末蓝、 2021-09-19 08:08 353阅读 0赞

配置应用
对一个使用 Flask-Login 的应用最重要的一部分就是 LoginManager 类。你应该在你的代码的某处为应用创建一个,像这样:
login_manager = LoginManager()

登录管理(login manager)包含了让你的应用和 Flask-Login 协同工作的代码,比如怎样从一个 ID 加载用户,当用户需要登录的时候跳转到哪里等等。
一旦实际的应用对象创建后,你能够这样配置它来实现登录:

login_manager.init_app(app)

或者直接

login_manager=LoginManager(app)

你必须提供一个 user_loader 回调。这个回调用于从会话中存储的用户 ID 重新加载用户对象。它应该接受一个用户的 unicode ID 作为参数,并且返回相应的用户对象。比如:

  1. @login_manager.user_loader
  2. def load_user(user_id):
  3. return User.query.get(user_id)

你用来表示用户的类需要实现这些属性和方法:
is_authenticated
当用户通过验证时,也即提供有效证明时返回 True。(只有通过验证的用户会满足 login_required 的条件。)

is_active
如果这是一个活动用户且通过验证,账户也已激活,未被停用,也不符合任何你 的应用拒绝一个账号的条件,返回 True。不活动的账号可能不会登入(当然, 是在没被强制的情况下)。

is_anonymous
如果是一个匿名用户,返回 True(真实用户应返回 False)

get_id()
返回一个能唯一识别用户的,并能用于从 user_loader 回调中加载用户的 unicode 。注意着 必须 是一个 unicode —— 如果 ID 原本是 一个 int 或其它类型,你需要把它转换为 unicode 。

你可用使用 current_user 代理来访问登录的用户,在每一个模板中都可以使用 current_user :
{% if current_user.is_authenticated() %}
Hi {{ current_user.name }}!
{% endif %}

需要用户登入 的视图可以用 login_required 装饰器来装饰:
@app.route(“/settings”)
@login_requireddef settings(): pass

当用户要登出时:
@app.route(“/logout”)
@login_requireddef logout():
logout_user()
return redirect(somewhere)
他们会被登出,且他们会话产生的任何 cookie 都会被清理干净。

登录视图的名称可以设置成 LoginManager.login_view 。
login_manager.login_view=’/regloginpage/‘
未登录会跳转的页面

登录模块

  1. @app.route('/login/',methods={'post','get'})
  2. def login():
  3. username = request.values.get('username').strip()
  4. password = request.values.get('password').strip()
  5. user=User.query.filter_by(username=username).first()
  6. if username == '' or password == '':
  7. return redirect_with_msg('/regloginpage/', u'用户名或密码不能为空', 'reglogin')
  8. if user== None:
  9. return redirect_with_msg('/regloginpage/', u'用户名不存在', 'reglogin')
  10. m=hashlib.md5()
  11. m.update((password+user.salt).encode("utf-8"))
  12. if m.hexdigest()!=user.password :
  13. return redirect_with_msg('/regloginpage/', u'密码错误', 'reglogin')
  14. login_user(user)
  15. next=request.values.get('next')
  16. if next!=None and next.startswith('/'):
  17. return redirect(next)
  18. return redirect('/')

发表评论

表情:
评论列表 (有 0 条评论,353人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Kotlin学习之 10扩展

    Kotlin 扩展 Kotlin 可以对一个类的属性和方法进行扩展,且不需要继承。 扩展是一种静态行为,对被扩展的类代码本身不会造成任何影响。 类的扩展,是什么鬼?