- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在围绕更新的范例重写一堆表单,试图简化用于防止在用户使用“后退”按钮播放时重新处理陈旧表单数据的机制。我已经将它提炼成一个最小的测试用例,它可以在 FF21、ie10(!)、Opera12.15 中运行,但仅适用于 Chrome 27.0 和 Safari 5.1.7——而不是我预期会出现问题的浏览器,所以这可能是我自己的错。
Form view.php 总是发布到 post.php,后者完成所有工作,然后重定向到 view.php。 (其中一些是设计页面,一些用户在其中重复多次。)我的目标是避免“浏览器必须重新提交数据”消息,防止浏览器使用缓存 View ,并防止 view.php 留下很长的历史上的踪迹。 (一些消息来源称 PRG 阻止了这种情况。)所有三个目标都在 FF、Opera 和 IE 中实现,在这些地方没有历史增长。 Chrome 和 Safari 在历史记录中显示了相同页面浏览量的轨迹。查看请求/响应 header ,Chrome 似乎对任何重新访问的历史页面进行了完整的 GET,但它在同一页面上显示历史和当前字段值的混合(!)。我认为这是对我来说最令人困惑的一个方面,即显示从未在一页上共存的值组合。在 Chrome 中查看源代码总是显示最新的副本。我说的是下面精确提炼的示例的行为,而不是它们的一些更复杂的版本。
字段一回应内部计数器并忽略用户输入。无论是否为只读,它的行为都一样奇怪。
字段二回应用户输入。我通常将第一个字段复制或附加到它。
view.php
<?php
session_start();
header('Cache-Control:private,no-store,no-cache,must-revalidate,post-check=0,pre-check=0');
header('Pragma: no-cache');
$cval = !isset($_SESSION['counter']) ? 0 : $_SESSION['counter'];
$word = !isset($_SESSION['word']) ? '' : htmlentities($_SESSION['word'],ENT_QUOTES,'UTF-8',FALSE);
echo <<<HTM
<pre>
<form method='POST' action='post.php'>
<input type='text' name='count' value='$cval'/>
<input type='text' name='word' value='$word'/>
<input type='submit' name='doit' value='Submit'/>
</form>
</pre>
HTM;
?>
post.php
<?php
session_start();
if(!isset($_SESSION['counter'])):
$_SESSION['counter'] = 1;
else:
$_SESSION['counter'] += 1;
endif;
$_SESSION['word'] = !isset($_POST['word']) ? '' : $_POST['word'];
header('Location: view.php');
?>
如果我开始备份历史记录,Chrome 往往会显示最新的字段一值,但会显示历史字段二值。有时它会在两者上显示历史。如果没有这种差异,我会假设无法阻止服务器(在配对网络上)或代理缓存页面。
如果我添加“Expires: -1” header ,它会做同样的事情。
我可以识别陈旧的表格;我似乎无法做的是阻止用户访问或提交用户。 view.php 上递增的 GET 参数将防止不可预测缓存 View ,但会在所有浏览器中创建一个明确的历史记录,并且只会邀请人们向后转动棘轮。
为什么会发生这种情况,是否可以解决?
最佳答案
在没有相反建议的情况下,我对 p-r-g 模型的实现似乎没有什么大错。 Firefox、IE 和 Opera 完全按照预期工作,而 Safari 只是盲目地将每个 GET 写入历史记录。但是 Safari 的历史记录很容易通过在表单中插入隐藏的或只读的新鲜度标记来处理,这样您就可以识别陈旧的表单。
障碍是 Chrome 的一个怪癖,我没有看到一个纯 PHP/HTML 的解决方法。 (正式报告,顺便说一句。)
这是新代码,只是稍微复杂一点,这使得行为非常清晰。只需提交几次,每次在 Inval 字段中输入不同的内容,然后回顾历史。
Chrome 总是能正确获取 View 的新副本,即使您返回到历史记录。但是,如果您重新访问访问 #x,Chrome 将覆盖您在访问 #x 上触摸的任何字段的预填充值,放入陈旧数据而不是新 View 指定的内容。 (检查字段 Inval 中的数据与其右侧显示的预填充值之间的不匹配。)这可以通过使用 JavaScript 重新预填充损坏的字段来解决,方法是将预填充数据从您嵌入页面的隐藏元素复制到损坏的字段中.
新的VIEW.PHP
<?php # view.php
session_start();
header('Cache-Control: private, no-store, no-cache, must-revalidate, max-age=0');
header('Pragma: no-cache');
header('Expires: -1');
# Format timestamp and counter
$tval = date("H:i:s");
$cval = !isset($_SESSION['counter']) ? 0 : $_SESSION['counter'];
# Format last-posted values for display but (mostly) not for prepopulation
$lphiddn = !isset($_SESSION['xhiddn']) ? '' : htmlentities($_SESSION['xhiddn'],ENT_QUOTES,'UTF-8',FALSE);
$lpcount = !isset($_SESSION['xcount']) ? '' : htmlentities($_SESSION['xcount'],ENT_QUOTES,'UTF-8',FALSE);
$lpinval = !isset($_SESSION['xinval']) ? '' : htmlentities($_SESSION['xinval'],ENT_QUOTES,'UTF-8',FALSE);
# Format pre-population data
$phiddn = "H $tval"; // H 00:00:00
$pcount = "(#$cval) $tval"; // (#1) 00:00:00
$pinval = $lpinval; // whatever was last posted for this field
echo <<<HTM
<pre style='font-family: monospace;'>
<form method='POST' action='post.php'>
Hiddn <input type='hidden' name='hiddn' value='$phiddn'/> prepop=$phiddn lastpost=$lphiddn
Count <input type='text' name='count' value='$pcount'/> prepop=$pcount lastpost=$lpcount
Inval <input type='text' name='inval' value='$pinval'/> prepop=$pinval = lastpost=$lpinval
Submt <input type='submit' name='doit' value='Submit'/>
</form>
</pre>
HTM;
?>
新的 POST.PHP
<?php # post.php
session_start();
header('Cache-Control: private, no-store, no-cache, must-revalidate, max-age=0');
header('Pragma: no-cache');
header('Expires: -1');
if(!isset($_SESSION['counter'])):
$_SESSION['counter'] = 1;
else:
$_SESSION['counter'] += 1;
endif;
$_SESSION['xhiddn'] = !isset($_POST['hiddn']) ? '' : $_POST['hiddn'];
$_SESSION['xcount'] = !isset($_POST['count']) ? '' : $_POST['count'];
$_SESSION['xinval'] = !isset($_POST['inval']) ? '' : $_POST['inval'];
header("HTTP/1.1 303 See Other");
header('Location: view.php');
?>
关于php - 更多重定向后获取问题,我做错了什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17247126/
我正在开发一个带选项卡栏的 ios 应用程序。我的栏上有超过 5 个按钮,所以在 iphone 上我有更多的按钮。现在,假设我有这个按钮:Button1 Button2 Button3 Button4
我有一个带有 UITabBarController 的应用,其中有超过五个选项卡。 当我按更多选项卡时,我会转到moreNavigationController,它是一个UINavigationCon
我有一个导航 Controller 。 NAVC->MORE... 按钮,然后在“更多”下有一些额外的 VC。 如果我转到“更多...”下的 VC,然后转到不在“更多...”上的 VC,那么当我返回到
因此,我想出了这种方案,用于在多个线程同时具有读写访问权限的二叉树中旋转时锁定节点,这涉及每次旋转锁定四个节点,这似乎是一个很多吗?我想到了一种比我想出的方法更聪明的方法来减少所需的锁定,但谷歌并没有
所以我已经尝试了所有方法,但我似乎仍然无法将下拉内容与 dropbtn 对齐。我只希望内容始终位于更多菜单下方。 HTML: `
我正在尝试使用 expect 来自动接受在 --more-- 中提示的 EULA。 #!/usr/bin/expect spawn "./greenplum-perfmon-web-4.1.2.0-b
他们如何在下面提供的网站上制作“告诉我更多”效果。我读过 read more/less effect in jQuery,但我发现该站点的有趣之处在于,除非单击该按钮,否则无法滚动页面。 Effect
现在,Kim Stebel helped me understanding如何使用存在类型键入变量,我需要知道如何在继承中使用它们: 以下代码无法编译: class PagingListModel(s
在我的Cygwin中不可用。另一方面,提供了“ less”命令。也许Cygwin的制造商认为“更多”只是多余的。 我对此很好奇。 最佳答案 安装util-linux软件包,您将获得“更多”的信息 ht
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我们使用 asp.net mvc、javascript 和 jQuery(托管在本地计算机上)创建了一个应用程序。基本设计是,当用户从一个页面导航到其他页面时,我们通过隐藏和显示 HTML 页面,将所
我想用 RMonad 做一些基本的事情。有没有办法使用“as monad”功能来 有一个身份 rmonad,可以应用 monad 转换器吗? 有诸如 StateT 变压器之类的常见东西吗? 向现有 m
我有一个 char*[] 数组。我需要能够为其分配字符串并再次删除它们,但我不知道: 如何检查一个元素中是否已经有一个字符串,这样我就不会覆盖它,如果它已经被占用,则继续处理下一个元素? 之后如何将其
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我有一个程序可以同时吐出标准错误和标准输出,我想在标准错误上少运行寻呼机,但忽略标准输出。我该怎么做? 更新: 就是这样......我不想丢失标准输出......只是让它远离寻呼机 program 2
基本上,当单击具有类 "dropdown" 的链接时,我无法获取“更多...”链接来对下一个跨度的高度进行动画处理。它根本就没有动画。仅当更改为 Less... 链接并且单击 Less... 链接以折
我正在使用 ExtJS,并认为它是一个了不起的框架。但是,它们没有内置的状态图,这使得依赖于状态的应用程序开发非常痛苦。 我最近发现了这个: https://github.com/jakesgordo
我一直在研究数据结构和算法,遗憾的是在C中。我已经单独实现了一个双向链表,它保存整数并且工作正常,但是当节点(或pub)让它正常工作时我遇到了很多麻烦在本例中)保存多个不同类型的值。我可以创建一个列表
编辑拼写错误 你好, 这可能是一个愚蠢的问题,但如果它能帮助我遵循最佳实践,我不在乎:P 假设我想在 System.Data 命名空间...以及 System.Data.SqlClient 命名空间中
使用 bootstrap 3 CSS、font awesome CSS 和最新的 jQuery JS 文件。 我正在使用 javascript 在单击按钮时在另一个内容 div 之上隐藏/显示一个内容
我是一名优秀的程序员,十分优秀!