这是我在PHP中执行的 *** 作:
<?php$fakeFileName= "fakeFileName.zip";$realFileName = "realFileName.zip";$file = "downloadFolder/".$realFileName;$fp = fopen($file, 'rb');header("Content-Type: application/octet-stream");header("Content-Disposition: attachment; filename=$fakeFileName");header("Content-Length: " . filesize($file));fpassthru($fp);?>
此外,如果您不希望任何人访问文件位置,请将名为的文件
.htaccess放入仅包含内容的下载文件夹中:
deny from all
我稍微修改了代码。首先,当我说假文件名和真实文件名时,假文件名就是下载程序将下载文件的名称,其中真实文件名是服务器上下载文件夹中实际文件的名称。
另外,我检查以确保用户已登录并能够下载文件。如果他选择下载文件,则在新选项卡中调用一个PHP文件(上面有下载代码),然后在文件末尾有以下一行:
exit;
因此,当他单击下载链接时,空白页会迅速在新选项卡中d出,然后迅速退出并开始下载。
编辑: 下载链接看起来像这样:
<a href="simpleDown.php?id=<?php echo $_GET['id']; ?>" target="_blank">Download!</a>
哪里
id是
id下载的数据库,并从上面我找到了进入的下载脚本
id,然后获取其真正的文件名和假文件名。您可以在没有数据库的情况下执行此 *** 作。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)