У меня проблема с загрузкой файлов с помощью PHP. Я думаю, что download.php не работает, и мне нужна помощь. когда я нажимаю кнопку загрузки, вместо загрузки файла он пытается открыть его как страницу и сообщает, что он недоступен на сервере, но есть. это сообщение об ошибке
кнопка веб-сайта
<a href = "download.php?id=<?=$results['file'];?>" ><button
class = "btn1">download</button></a>
download.php
if (isset($_POST['id'])) {
$stat=$conn->prepare("SELECT * FROM complete WHERE id=?");
$stat->bindParam(1,$id);
$stat->execute();
$data = $stat->fetch(PDO::FETCH_ASSOC);
$file = 'files/'.$data['filename'];
if (file_exists($file)) {
header('Content-Description:'.$data['description']);
header('Content-Type:'.$data['type']);
header('Content-Disposition:'.$data['disposition'].';filename = "'.basename($file).'"');
header('Expires:'.$data['expires']);
header('Cache-Control:'.$data['cache']);
header('Pragma:'.$data['pragma']);
header('Content-Length:'.filesize($file));
readfile($file);
exit();
}
}
?>
use @readfile($file) для вывода сообщений об ошибках.
@Kalu @ почти всегда плохая идея. На самом деле он СКРЫВАЕТ сообщения об ошибках.
<button> внутри <a> ??? Вы можете попробовать атрибут HTML5 download: <a href = "download.php?id=<?=$results['file'];?>" download>Download</a>Кроме того, здесь возникает реальная проблема безопасности. Каждый может загрузить любой файл, изменив идентификатор в URL-адресе. Вы должны подтвердить, что загружающий файл также является владельцем загруженного файла.
@RiggsFolly ты прав. должно быть наоборот.
@peter: - stackoverflow.com/questions/20367104/…
элемент button по умолчанию пытается отправить форму, что здесь не имеет смысла. Если вы хотите получить ссылку, которая выглядит как кнопка, вы можете просто использовать базовый CSS, на самом деле bootstrap.css имеет встроенную функцию.
все там решения не работают. Я пытаюсь реализовать их и каждый раз сталкиваюсь с одной и той же проблемой. у кого-нибудь есть код, который обязательно сработает?
Извините за это, не знаю, почему я думал, что вы используете MySQLI






Вы можете проверить сообщение об ошибке? Вы забыли поместить туда настоящее сообщение об ошибке? Спасибо