Richard Davey wrote:
> Mário Gamito wrote:
>
>> To prevent people to insert the full URL to the documents, i moved
>> them outside Apache's DocumentRooot, which is /var/www.
>>
>> My site is in /var/www/telbit and i put the PDFs in /var/www
>>
>> I've coded in order to do the trick, but it's failing.
>> I can't get the name of the file.
>
> You don't need to basename() it, you already know what the filename is,
> because it was requested via $_GET['file'].
I would say almost the opposite:
<?php
if (isset($_SESSION['email'])) {
$error = false;
if (isset($_GET['file'])) {
$file = basename($_GET['file']);
$full = '/var/www/' . $file;
if (!is_readable($full))
$error = "Invalid filename.";)
} else {
$error = "No filename given.";
}
if ($error) {
echo "<a href=\"products-teststudio.php?file=testudio.pdf\"",
" rel=\"external\">Download TESTUDIO flyer</a>";
exit;
}
header('Content-type: application/pdf');
header("Content-Length: " . filesize($full));
header('Content-disposition: attachment; filename="'. $file .'"');
readfile($full);
exit;
} else {
echo "Unauthorized Access!";
}
>
> I would insert a file_exist check before you try and send it. It might
> give you the cause of your problem.
always a good thing
>
> Cheers,
>
> Rich
--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php