PHP防止注销后返回页面 - php

我有一个受保护的页面,该页面仅显示登录用户的数据,一旦用户单击注销链接,它将破坏会话数据并重定向到另一个页面。 header('Location: login.php');

现在,一旦页面重定向到login.php,我就可以轻松地返回到受保护的后页,并且可以在那里查看所有信息,并且可以保留在该页面上,直到我刷新浏览器或关闭它。

在Gmail等网站以及许多其他网站上,登录后就无法返回上一页。如何实现呢?
谢谢。

编辑:很抱歉,如果不清楚,受保护的页面顶部没有几行代码来检查是否设置了会话。如果未设置会话,则应重定向到其他页面。但问题是,如果我在浏览器上点击了后退按钮,它不会检查会话。

参考方案

此行为可能是由浏览器/ Web服务器的默认缓存设置引起的。

每当用户访问受保护的页面时,请尝试发送标题以防止页面缓存:

header('Cache-Control: no-cache, must-revalidate');
header('Expires: Sat, 26 Jul 1997 05:00:00 GMT');

通常,这应该导致任何后退按钮的按下都导致页面的完全重新加载,而不是从浏览器的缓存中加载页面。

PHP Memcached会话突然失效 - php

session.save_handler = memcached session.save_path = "127.0.0.1:11211" session.gc_maxlifetime = 86400 其余的标准。我希望自上次用户访问该页面以来,该会话至少可以保留86400秒,即,如果我在5分钟后启动了一个会话并访问了该页面,则该会话应…

PHP-全局变量的性能和内存问题 - php

假设情况:我在php中运行一个复杂的站点,并且我使用了很多全局变量。我可以将变量存储在现有的全局范围内,例如$_REQUEST['userInfo'],$_REQUEST['foo']和$_REQUEST['bar']等,然后将许多不同的内容放入请求范围内(这将是适当的用法,因为这些数据指的是要求自…

php-casperjs获取内部文本 - php

我正在为casperjs使用php包装器-https://github.com/alwex/php-casperjs我正在网上自动化一些重复的工作,我需要访问一个项目的innerText,但是我尚不清楚如何从casperjs浏览器访问dom。我认为在js中我会var arr = document.querySelector('label.input…

PHP getallheaders替代 - php

我正在尝试从服务器上的apache切换到nginx。唯一的问题是我在PHP脚本中使用的getallheaders()函数,该函数不适用于Nginx。我已经尝试过用户在getallheaders函数上的php站点上提供的注释,但这并不返回所有请求标头。请告诉我如何解决这个问题。我真的想切换到Nginx。 参考方案 您仍然可以使用它,但是您必须像这里一样重新定义…

PHP:将字符串拆分为字母和数字部分的最佳方法 - php

我有几个格式的字符串AA11 AAAAAA1111111 AA1111111 分离字符串的字母和数字部分的最佳方法(最有效)? 参考方案 如果它们都是一系列字母,然后是一系列数字,并且没有非字母数字字符,那么sscanf()可能比regexp更有效$example = 'AAA11111'; list($alpha,$numeric) =…