为什么不将此代码放在单独的文件中,例如download.php
:
<?php
$file = "logs/{$session->username}.txt";
if(!file_exists($file)) die("I'm sorry, the file doesn't seem to exist.");
$type = filetype($file);
// Get a date and timestamp
$today = date("F j, Y, g:i a");
$time = time();
// Send file headers
header("Content-type: $type");
//** If you think header("Content-type: $type"); is giving you some problems,
//** try header('Content-Type: application/octet-stream');
//** Note filename= --- if using $_GET to get the $file, it needs to be "sanitized".
//** I used the basename function to handle that... so it looks more like:
//** header('Content-Disposition: attachment; filename=' . basename($_GET['mygetvar']));
header("Content-Disposition: attachment;filename={$session->username}.txt");
header("Content-Transfer-Encoding: binary");
header('Pragma: no-cache');
header('Expires: 0');
// Send the file contents.
set_time_limit(0);
ob_clean();
flush();
readfile($file);
//** If you are going to try and force download a file by opening a new tab via javascipt
//** (In this code you would replace the onClick() event handler in the html
//** button with onclick="window.open('www.someurl.com', '_blank');"
//** - where 'www.someurl.com' is the url to the php page - I keep the file
//** creation and download handling in the same file, and $_GET the file name
// - bad practice? Probably, but I never claimed to be an expert),
//** be sure to include exit(); in this part of the php...
//** otherwise leave exit(); out of the code.
//** If you don't, it will likely break the code, based on my experience.
//exit();
?>
请注意,您必须将引号更改为双引号,因为您在'
s 中使用变量。因此,要扩展变量,请将第一行更改为:
$file = "logs/{$session->username}.txt";
在这里,我认为 ,$session->username
作为您要引用的变量。
并在 HTML 中有这个:
<button type="button" onclick="location.href='download.php'">Download All Your Keys On A .txt</button>
当您单击此按钮时,它会重定向到download.php
,启动 txt 文件的下载。就如此容易。但这需要你有两个文件。而且我不明白这里需要一个按钮。为什么不只使用这样的简单链接?
<a href="download.php">Download All Your Keys On A .txt</a>
如果需要,您可以使用 CSS 对其进行样式设置。