我正在开发一个快速类似用户的网站,用户可以下载文件。首先,我创建了一个快速测试设置标题并使用readfile()
,但后来我发现in the comments section有一种限制下载速度的方法,这很好,这是代码:
$local_file = 'file.zip';
$download_file = 'name.zip';
// set the download rate limit (=> 20,5 kb/s)
$download_rate = 20.5;
if(file_exists($local_file) && is_file($local_file))
{
header('Cache-control: private');
header('Content-Type: application/octet-stream');
header('Content-Length: '.filesize($local_file));
header('Content-Disposition: filename='.$download_file);
flush();
$file = fopen($local_file, "r");
while(!feof($file))
{
// send the current file part to the browser
print fread($file, round($download_rate * 1024));
// flush the content to the browser
flush();
// sleep one second
sleep(1);
}
fclose($file);}
else {
die('Error: The file '.$local_file.' does not exist!');
}
但现在我的问题是,如何同时限制下载次数?如何检查是否仍存在与某个用户IP的连接?
感谢。
答案 0 :(得分:3)
用户是否有登录信息?如果不是只使用会话,甚至更好地跟踪他们的IP地址。
这是一个会话示例:
$_SESSION['file_downloading']==true;
$file = fopen($local_file, "r");
while(!feof($file))
{
// send the current file part to the browser
print fread($file, round($download_rate * 1024));
// flush the content to the browser
flush();
// sleep one second
sleep(1);
}
$_SESSION['file_downloading']=null;
fclose($file);}
然后是所有这些代码,
if(!empty($_SESSION['file_downloading']))
//执行重定向或降低下载速率等。
下一个选项是通过IP地址。
//http://wiki.jumba.com.au/wiki/PHP_Get_user_IP_Address
function VisitorIP()
{
if(isset($_SERVER['HTTP_X_FORWARDED_FOR']))
$TheIp=$_SERVER['HTTP_X_FORWARDED_FOR'];
else $TheIp=$_SERVER['REMOTE_ADDR'];
return trim($TheIp);
}
获取访客IP地址,将其与日期时间戳一起存储在数据库中。然后在文件下载完成后删除该IP地址。你在使用数据库系统吗?