请教大家个问题,flask写web项目,怎么设置不同的用户有不同的权限呢?谢谢大家啦
比如:管理员具有一切的操作权限,一般用户只有增加数据没有删除数据的权限呢?
设置flask-web项目用户权限
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
ShowMeAI 2022-12-06 21:39关注望采纳
我们可以基于 Flask 和 Flask-Login 来设置不同用户权限:
示例如下:
from flask import Flask from flask_login import LoginManager, UserMixin, login_required, login_user, logout_user app = Flask(__name__) # 定义用户类,继承了 UserMixin 类,其中包含了 is_authenticated, is_active, is_anonymous # 这三个属性默认为 False,需要重写它们。 class User(UserMixin): def __init__(self, id): self.id = id self.name = "user" + str(id) self.password = self.name + "_secret" def __repr__(self): return "%d/%s/%s" % (self.id, self.name, self.password) # 初始化 Flask-Login,并将 User 实例注册到 LoginManager 实例中。 login_manager = LoginManager() login_manager.init_app(app) # 定义 load_user 函数,通过 id 获取对应的 User 实例。 @login_manager.user_loader def load_user(user_id): return User.get(user_id) # 下面是 Flask 应用的路由视图函数。 # 用于登录的路由。 @app.route("/login") def login(): user = User.get(request.form['username']) if (user and user.password == request.form['password']): login_user(user) return redirect(request.args.get("next")) else: return abort(401) # 用于登出的路由。 @app.route("/logout") @login_required def logout(): logout_user() return Response(' Logged out ') # 只有认证过的用户才能访问该路由。 @app.route("/protected") @login_required def protected(): return Response(" Protected ")解决 无用评论 打赏 举报