防止通过后退按钮重新提交表单 + refresh/retry

Prevent form resubmit by back button + refresh/retry

如果有人问过这个问题,我深表歉意,但我已经做了很多搜索,但还没有找到与我类似的问题。

在我的应用程序中,我有一个密码更改页面,如果某人是新用户或 his/her 密码重置,该页面就会触发。

问题是,一旦用户进行更改并点击提交,he/she 就会被重定向到主页。现在,如果用户多次点击后退按钮以进入密码更改页面,他们会遇到一个过期的页面,他们可以点击刷新。然后浏览器要求用户重试提交数据。本次提交请求是一个POST,在数据包中可以看到用户之前输入的原始数据。

到目前为止,我只能在 IE 上重现这个问题..在 FF 和 Chrome 上试过,但什么也没有。

我的问题是,有没有办法使用 jQuery、HTML、WSS 或其他方式来防止 POST 被重新提交?我最关心的是可以看到数据的数据包。

谢谢。

此类问题的一个非常通用的解决方案是 Post/Redirect/Get-pattern。

这意味着当您想对某个页面执行 POST 操作以在后台更新某些内容时,您实际上创建了两个目标页面:

页码1

POST 的目标页面。包含更新 database/filesystem/API 或任何需要完成的逻辑。这只是一个 URL,没有任何真实的视觉反馈,而是在逻辑完成后将您重定向到第 2 页(见下文)。重定向是一个简单的 GET 而不是 POST.

页码2

一个页面,显示您对 "page number 1" 上的操作的反馈。可能只是一条消息 "Password update OK" 或来自数据库的实际数据或任何适合您的内容。

现在,当有人使用您的表单时,他们会被发布到将执行后台操作的第 1 页,然后他们将被重定向到第 2 页。

现在,如果他们重新加载,他们将不会重做整个逻辑部分,而只会重做反馈部分。

维基百科对此有很好的解释:

https://en.wikipedia.org/wiki/Post/Redirect/Get

如何在 Progress WebSpeed 中进行重定向

在你的 outputHeader-procedure 或你做过的任何地方

output-content-type ("text/html":U).

相反,如果输出内容类型:首先执行您的逻辑,然后插入如下内容:

OUTPUT-HTTP-HEADER("Status", "301").
OUTPUT-HTTP-HEADER("Location","http://www.yoursite.com/newurl").
OUTPUT-HTTP-HEADER("","").

现在,一旦逻辑处理完毕,您将在服务器端重定向。如果需要,您还可以在 url 中插入参数:

DEFINE VARIABLE iId as INTEGER NO-UNDO.
OUTPUT-HTTP-HEADER("Status", "301").
OUTPUT-HTTP-HEADER("Location","http://www.yoursite.com/newurl?id=" + STRING(iId)).
OUTPUT-HTTP-HEADER("","").