【问题标题】:Browser caching issues in flask烧瓶中的浏览器缓存问题
【发布时间】:2012-11-25 22:07:24
【问题描述】:

我已经使用烧瓶 (www.csppdb.com) 建立了一个网站。有时当我以一个用户身份登录,注销,然后以另一个用户身份登录时,我仍然会看到我登录的第一个用户的页面。此问题在页面刷新时立即修复。如果我没记错的话,我认为这被称为“缓存”。有什么方法可以在站点范围内禁用此功能,以便访问的每个页面都需要重新刷新?

这就像与朋友共享您的计算机。他登录 Facebook,然后退出。现在你登录他的电脑,你会看到他的个人资料……(尴尬)。刷新页面后问题就解决了。

这是我的一些代码。我使用的是烧瓶登录,但后来我尝试“自己动手”

from flask.ext.mysql import MySQL
import os
from flask import Flask, request, jsonify, session, url_for, redirect, \
     render_template, g, flash
from data import *
from werkzeug import check_password_hash, generate_password_hash
import config

app = Flask(__name__)
mysql = MySQL()

app.config['MYSQL_DATABASE_HOST'] = os.environ['MYSQL_DATABASE_HOST'] if 'MYSQL_DATABASE_HOST' in os.environ else config.MYSQL_DATABASE_HOST
app.config['MYSQL_DATABASE_PORT'] = os.environ['MYSQL_DATABASE_PORT'] if 'MYSQL_DATABASE_PORT' in os.environ else config.MYSQL_DATABASE_PORT
app.config['MYSQL_DATABASE_USER'] = os.environ['MYSQL_DATABASE_USER'] if 'MYSQL_DATABASE_USER' in os.environ else config.MYSQL_DATABASE_USER
app.config['MYSQL_DATABASE_PASSWORD'] = os.environ['MYSQL_DATABASE_PASSWORD'] if 'MYSQL_DATABASE_PASSWORD' in os.environ else config.MYSQL_DATABASE_PASSWORD
app.config['MYSQL_DATABASE_DB'] = os.environ['MYSQL_DATABASE_DB'] if 'MYSQL_DATABASE_DB' in os.environ else config.MYSQL_DATABASE_DB

mysql.init_app(app)

if 'SECRET_KEY' in os.environ: app.config['SECRET_KEY'] = os.environ['SECRET_KEY']
else: app.config['SECRET_KEY'] = os.urandom(24)

def connect_db(): return mysql.connect()

def check_auth():
    g.user = None
    if 'username' in session:
        g.user = get_user(session['username'])
        return
    return redirect(url_for('login'))

@app.route('/')
def home(): 
    if 'username' in session: return redirect(url_for('main'))
    return render_template('home.html')

def connect_db(): return mysql.connect()

@app.teardown_request
def teardown_request(exception):
    if exception: print exception
    g.db.close()

@app.before_request
def before_request():
    print session.keys(), session.values()
    print("before request")
    print ('username' in session, "in session?")
    g.db = connect_db()
    g.user = None
    if "username" in session:
        g.user = get_user(session['username'])


@app.route('/login/', methods=['GET', 'POST'])
def login():
    """Logs the user in."""
    if 'username' in session:
        return redirect(url_for('main'))

    error = None
    if request.method == 'POST':
        print("login hit")
        user = get_user(request.form['username'])
        if user is None:
            error = 'Invalid username'
            print error
        elif not check_password_hash(user.password, request.form['password']):
            error = 'Invalid password'
            print error
        else:
            flash('You were logged in')
            print "logged in"
            session['username'] = request.form['username']
            g.user = request.form['username']
            print error, "error"
            return redirect(url_for('main'))

    return render_template('login.html', error=error)

【问题讨论】:

  • 在你不在这里放置任何代码之前,没有人可以说你什么,例如登录和注销视图以及此错误所在的模板示例。
  • @Denis,请看附件代码
  • 用户如何注销?代码不包括在内,我想知道您是如何处理会话的。
  • 注销只是将用户从会话中弹出。 session.pop('用户名', 无)

标签: python caching flask browser-cache


【解决方案1】:

将缓存设置为 max-age=0 进行修复。

@app.after_request
def add_header(response):
    """
    Add headers to both force latest IE rendering engine or Chrome Frame,
    and also to cache the rendered page for 10 minutes.
    """
    response.headers['X-UA-Compatible'] = 'IE=Edge,chrome=1'
    response.headers['Cache-Control'] = 'public, max-age=0'
    return response

【讨论】:

【解决方案2】:

要在此类页面上停止浏览器缓存,您需要设置一些 HTTP 响应标头。

Cache-Control: no-cache, no-store
Pragma: no-cache

一旦你这样做了,浏览器就不会缓存这些页面。我不知道如何使用“flask”来做到这一点,所以我会把它留给你作为练习:)

这个问题展示了如何添加响应头Flask/Werkzeug how to attach HTTP content-length header to file download

【讨论】:

  • 这个http头应该在服务器的http响应中设置
  • @Dave 更新了答案以包含一个显示如何添加响应标头的问题
猜你喜欢
  • 2021-03-24
  • 1970-01-01
  • 1970-01-01
  • 2015-03-02
  • 2015-08-05
  • 2011-08-22
  • 2011-10-14
  • 2011-08-18
相关资源
最近更新 更多