超时后按提交按钮重置 websocket 页面

问题描述

我遇到了一个问题,即在 Flask websocket 中做了一些工作后,我有一个页面 (A) 重定向页面 (B)。页面 (B) 有另一个 websocket,它可以完成更长时间的工作 10-20 分钟,然后有一个按钮可以继续到有一些结果的第三页 (C)。我面临的问题是在页面 (B) 上时,工作已经完成,我准备单击按钮继续页面 (C),如果时间足够长(15 分钟以上,不确定是否准确),当我单击按钮时,它会刷新到页面 (A) 并且我的所有数据都消失了。如果经过了相当短的时间,页面继续到页面 (C) 就好了。我最好把这个时间延长到几个小时。

我不确定出了什么问题,所以我尝试修改 before_request 中的会话数据

from datetime import datetime,timedelta,timezone
from flask import redirect,request,session,url_for,jsonify,g
from config import *
from dateutil import parser


#  Page Functions
@app.before_request
def before_request():
    # function runs before the request for a page to see if the user is logged in or not

    session['fresh'] = True
    g.user = None
    g.ldap_groups = None
    if 'user_id' in session:
        g.user = session['user_id']
    if 'samlUserdata' in session:
        if 'ldapGroups' in session['samlUserdata']:
            g.ldap_groups = session['samlUserdata']['ldapGroups']
    if 'samlExpiration' in session and request.endpoint != 'login':
        if session['samlExpiration'] < datetime.Now():
            session.clear()
            return redirect(url_for('login'))
        if 'IdentityExpires' in session:
            Now = datetime.Now(timezone.utc)
            if parser.parse(session['IdentityExpires']) < Now:
                session.clear()
                return redirect(url_for('login'))
        else:
            session['samlExpiration'] = datetime.Now() + timedelta(minutes=SESSION_LENGTH)
        # Manage session timeout
    session.permanent = True
    session.permanent_session_lifetime = timedelta(days=1)
    session.modified = True

但这并不能解决问题。

我的flask实例如下:

from flask import Flask
from flask_socketio import SocketIO
from config import *

app = Flask(__name__)
app.config.from_object('config')
socketio = SocketIO(app,async_mode=async_mode,message_queue=app.config['CELERY_broKER_URL'],ping_timeout=SOCKETIO_PING_TIMEOUT,ping_interval=SOCKETIO_PING_INTERVAL)

任何指导将不胜感激!

解决方法

我想出了如何根据 before_request 函数解决这个问题。我的逻辑错了。

这是使它对我有用的新功能。

@app.before_request
def before_request():
    # function runs before the request for a page to see if the user is logged in or not

    session['fresh'] = True
    g.user = None
    g.ldap_groups = None
    if 'user_id' in session:
        g.user = session['user_id']
    if 'samlUserdata' in session:
        if 'ldapGroups' in session['samlUserdata']:
            g.ldap_groups = session['samlUserdata']['ldapGroups']
    if 'samlExpiration' in session and request.endpoint != 'login':
        if session['samlExpiration'] < datetime.now():
            session.clear()
            return redirect(url_for('login'))
        if 'IdentityExpires' in session:
            now = datetime.now(timezone.utc)
            if parser.parse(session['IdentityExpires']) < now:
                session.clear()
                return redirect(url_for('login'))
    else:
        session['samlExpiration'] = datetime.now() + timedelta(minutes=SESSION_LENGTH)