一可能的解决办法在客户机上使用JavaScript。
客户端算法:生成一个随机唯一的令牌。
提交下载请求,并将令牌包含在GET/POST字段中。
显示“等待”指示器。
启动一个计时器,每一秒左右,查找一个名为“fileDownloadToken”的cookie(或您决定的任何内容)。
如果存在cookie,并且其值与令牌匹配,则隐藏“等待”指示符。
服务器算法:在请求中查找get/post字段。
如果它具有非空值,则删除cookie(例如“fileDownloadToken”),并将其值设置为令牌的值。
客户端源代码(JavaScript):function getCookie( name ) {
var parts = document.cookie.split(name + "=");
if (parts.length == 2) return parts.pop().split(";").shift();}function expireCookie( cName ) {
document.cookie =
encodeURIComponent(cName) + "=deleted; expires=" + new Date( 0 ).toUTCString();}function setCursor( docStyle, buttonStyle ) {
document.getElementById( "doc" ).style.cursor = docStyle;
document.getElementById( "button-id" ).style.cursor = buttonStyle;}function setFormToken() {
var downloadToken = new Date().getTime();
document.getElementById( "downloadToken" ).value = downloadToken;
return downloadToken;}var downloadTimer;var attempts = 30;// Prevents double-submits by waiting for a cookie from the server.
function blockResubmit() {
var downloadToken = setFormToken();
setCursor( "wait", "wait" );
downloadTimer = window.setInterval( function() {
var token = getCookie( "downloadToken" );
if( (token == downloadToken) || (attempts == 0) ) {
unblockSubmit();
}
attempts--;
}, 1000 );}function unblockSubmit() {
setCursor( "auto", "pointer" );
window.clearInterval( downloadTimer );
expireCookie( "downloadToken" );
attempts = 30;}
示例服务器代码(PHP):$TOKEN = "downloadToken";// Sets a cookie so that when the download begins the browser can
// unblock the submit button (thus helping to prevent multiple clicks).
// The false parameter allows the cookie to be exposed to JavaScript.$this->setCookieToken( $TOKEN, $_GET[ $TOKEN ], false );
$result = $this->sendFile();
其中:public function setCookieToken(
$cookieName, $cookieValue, $httpOnly = true, $secure = false ) {
// See: http://stackoverflow.com/a/1459794/59087
// See: http://shiflett.org/blog/2006/mar/server-name-versus-http-host
// See: http://stackoverflow.com/a/3290474/59087
setcookie(
$cookieName,
$cookieValue,
2147483647, // expires January 1, 2038
"/", // your path
$_SERVER["HTTP_HOST"], // your domain
$secure, // Use true over HTTPS
$httpOnly // Set true for $AUTH_COOKIE_NAME
);}
本文介绍了如何通过JavaScript和PHP在客户端和服务器端实现防止文件下载请求重复提交的机制。客户端生成唯一令牌并提交下载请求,同时显示等待指示器和定时检查特定cookie。服务器接收到请求后设置cookie,当cookie出现并匹配时,客户端解除提交按钮的锁定状态。
921

被折叠的 条评论
为什么被折叠?



