使用 后退键/history.back()出现"警告: 网页已过期的解决办法"

本文探讨了解决在使用session_start后出现的“网页已过期”警告问题的方法。提供了三种解决方案,包括修改PHP代码、调整session设置及更改php.ini配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



原因:
表单提交页面中使用了 session_start 函数。由于我们后退浏览的是缓存页,而该函数会强制当前页面不被缓存。

另外加一句:笔者发现跟post和get有关系,get页面没有发生此类问题。
解决:
php:
此提示出现在一个POST提交的页面,点到其它页面后,通过JavaScript再返回时,IE就会显示这个提示。以前也有碰到过好多次,不过都没太在意,百度一下原来是session在作怪。
在通过IE的后退按钮或者网页中的history.go(-1)时,我们看到的将是缓存页,但使用了session_start后,这个函数会强制当前页面不被缓存,导致出现“警告: 网页已经过期”。
解决方法一:
在session_start之后加一句header("Cache-control: private"); 注意在此之前程序不能有任何输出。
注意在本行之前你的PHP程序不能有任何输出和空白

解决方法二:基于session的解决方法
在session_start前加上session_cache_limiter('private'); //不清空表单,只在session生效期间
session_cache_limiter还有另两个参数的含义:
session_cache_limiter('nocache');// 清空表单
session_cache_limiter('public'); //不清空表单,如同没有使用session 
解决方案三:
 更改配置文件php.ini。将该文件中session.cache_limiter = nocache改为session.cache_limiter = 或者session.cache_limiter = none,然后重新启动apache。
java:
使用javascript的history.back()进行返回时,有时会提示“网页已过期”,多数是因为目标页面的form为post提交方式,而且是表单已经提交后的响应页面,无法找到form中的具体参

数,而“报错”,具体解决办法:
一、在要返回的目标页面中,添加<%response.setHeader("cache-control","public"); %>
二、将目标页面的form的method="post"去掉,或改为method="get"。

当你在命令行中遇到"zsh: locking failed for /root/.zsh_history: 只读"的错误消息时,它意味着你的操作系统中的Zsh shell无法将当前用户的命令历史记录文件写入到/root/.zsh_history中,因为该文件是只读的。 通常,当你使用Zsh shell时,它会尝试将你在终端中输入的每个命令都记录到一个历史记录文件中,以便你在以后的会话中可以检索和重复执行之前的命令。 然而,/root/.zsh_history是存储命令历史记录的文件,而且它属于根用户(root)。根用户的文件通常是只读的,这意味着普通用户无法更改或写入这些文件。 当你作为普通用户运行Zsh shell时,它会尝试锁定/root/.zsh_history文件,以便其他进程或用户无法同时读取或写入它。但由于文件是只读的,它无法锁定文件,从而导致了"locking failed for /root/.zsh_history: 只读"的错误消息。 为了解决这个问题,你有几个选项: 1. 在Zsh shell中禁用命令历史记录:你可以在Zsh配置文件(通常是~/.zshrc)中注释掉关于命令历史记录的行。这样,Zsh将不再尝试将命令记录到/root/.zsh_history文件中。 2. 更改命令历史记录文件位置:你可以将命令历史记录文件的位置更改为另一个你有写入权限的目录。你可以通过修改Zsh配置文件中的HISTFILE变量来实现。 3. 以根用户身份更改文件权限: 如果你有根用户的权限,你可以更改/root/.zsh_history文件的权限,使其对普通用户可写。 无论你选择哪种解决方案,都应该记住,改变重要的系统文件的权限可能会对系统的安全性和稳定性产生风险,所以请谨慎操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值