Flask-Sockets和Flask-Login联合实现websocket的登录认证功能

flask_login 提供了一个方便的方式来管理用户会话。当你在 Flask 的 HTTP 视图中使用它时,你可以简单地使用 @login_required 装饰器来确保用户已登录。

但是,flask_sockets 并没有直接与 flask_login 集成。如果你想在建立 WebSocket 连接时检查用户是否已登录,你需要采取一些额外的步骤。

以下是一个示例,说明如何在 flask_sockets 路由中使用 flask_login 进行身份验证:

  1. 初始化 Flask、Flask-Login 和 Flask-Sockets
python 复制代码
from flask import Flask, request, session
from flask_login import LoginManager, current_user, UserMixin, login_required
from flask_sockets import Sockets

app = Flask(__name__)
app.config['SECRET_KEY'] = 'your-secret-key'
sockets = Sockets(app)
login_manager = LoginManager()
login_manager.init_app(app)
  1. 定义用户模型和加载用户的回调
python 复制代码
class User(UserMixin):
    # For simplicity, this example does not use a real database.
    # Instead, it uses this dictionary to simulate user data.
    users = {"1": {"id": "1", "username": "user1", "password": "pass1"}}

    def __init__(self, id_, username):
        self.id = id_
        self.username = username

    @classmethod
    def get(cls, id_):
        user_data = cls.users.get(id_)
        if not user_data:
            return None
        return User(id_=user_data["id"], username=user_data["username"])

@login_manager.user_loader
def load_user(user_id):
    return User.get(user_id)
  1. 定义 WebSocket 路由并检查登录状态

为了检查用户是否已登录,我们会读取 Flask 的会话数据,因为 flask_login 在其中存储了有关用户身份的信息。

python 复制代码
@sockets.route('/socket')
def chat_socket(ws):
    # Flask's context might not be available in the WebSocket route,
    # so we manually load the user using Flask-Login's method.
    user = load_user(session.get("user_id"))

    # If user is not loaded (i.e., not logged in), we close the connection.
    if user is None:
        ws.close(reason="User not logged in.")
        return

    while not ws.closed:
        message = ws.receive()
        if message:
            ws.send(f"Hello {user.username}, you said: {message}")
  1. 创建一些基本的登录和注销路由
python 复制代码
from flask import render_template, redirect, url_for, request

@app.route('/login', methods=["GET", "POST"])
def login():
    if request.method == "POST":
        username = request.form.get("username")
        password = request.form.get("password")
        user = [u for u in User.users.values() if u["username"] == username and u["password"] == password]
        if user:
            user = User.get(user[0]["id"])
            login_user(user)
            return redirect(url_for("index"))
    return render_template("login.html")

@app.route('/logout')
@login_required
def logout():
    logout_user()
    return redirect(url_for("login"))

@app.route('/')
@login_required
def index():
    return "Logged in as " + current_user.username
  1. 运行应用程序
python 复制代码
if __name__ == "__main__":
    from gevent.pywsgi import WSGIServer
    from geventwebsocket.handler import WebSocketHandler
    server = WSGIServer(('127.0.0.1', 5000), app, handler_class=WebSocketHandler)
    server.serve_forever()

注意:在上述代码中,我们手动加载用户并检查他们是否已登录,而不是使用 @login_required 装饰器。在 WebSocket 路由中,由于 Flask 的请求上下文可能不可用,所以这是必要的。

相关推荐
Hgfdsaqwr1 天前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
开发者小天1 天前
python中For Loop的用法
java·服务器·python
老百姓懂点AI1 天前
[RAG实战] 向量数据库选型与优化:智能体来了(西南总部)AI agent指挥官的长短期记忆架构设计
python
喵手1 天前
Python爬虫零基础入门【第九章:实战项目教学·第15节】搜索页采集:关键词队列 + 结果去重 + 反爬友好策略!
爬虫·python·爬虫实战·python爬虫工程化实战·零基础python爬虫教学·搜索页采集·关键词队列
Suchadar1 天前
if判断语句——Python
开发语言·python
ʚB҉L҉A҉C҉K҉.҉基҉德҉^҉大1 天前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
喵手1 天前
Python爬虫零基础入门【第九章:实战项目教学·第14节】表格型页面采集:多列、多行、跨页(通用表格解析)!
爬虫·python·python爬虫实战·python爬虫工程化实战·python爬虫零基础入门·表格型页面采集·通用表格解析
0思必得01 天前
[Web自动化] 爬虫之API请求
前端·爬虫·python·selenium·自动化
莫问前路漫漫1 天前
WinMerge v2.16.41 中文绿色版深度解析:文件对比与合并的全能工具
java·开发语言·python·jdk·ai编程
木头左1 天前
Backtrader框架下的指数期权备兑策略资金管理实现与风险控制
python