我在我的 PHP 中遇到了一个小问题。
目的是创建一个 mySQL 数据库,然后创建 PHP 页面来上传、列出和下载文件。
mySQL,上传和列表页面都很好,但是当我尝试下载时,我得到的不是文件,而是源代码,或者什么都没有。
你能帮我看看我的错误吗?
这是 read.php 的脚本(用于文件列表)
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title>Carica file nel database</title>
</head>
<p><b>Clicca su uno dei seguenti file</b><p><p></p>
<?php
include ("config.php");
include ("menu.php");
// connessione e selezione del database
mysql_connect('localhost', $userdb, $passdb)
or die('Connessione non riuscita: ' . mysql_error());
if(!mysql_select_db($database))
die('Selezione database fallita!');
// query per ottenere l'elenco dei files nel DB
$query = "SELECT * FROM data";
$risultato = mysql_query($query)
or die('Query non valida: ' . mysql_error());
// se ci sono files nel DB
if(mysql_numrows($risultato))
{
// estrazione dei risultati e stampa dei link ai files
while ($tmp = mysql_fetch_array($risultato))
{
echo "<p><a href=\"mostra.php?id=$tmp[id]\">$tmp[titolo]</a></p>\n";
}
}
else
{
echo '<p>Nessun file presente nel database</p>';
}
?>
<body></body>
</html>
而应该让我下载文件的 mostra.php (意思是意大利语中的“显示”)是:
<?php
include ("config.php");
include ("menu.php");
// connessione e selezione del database
mysql_connect('localhost', $userdb, $passdb)
or die('Connessione non riuscita: ' . mysql_error());
if(!mysql_select_db($database))
die('Selezione database fallita!');
// query per recuperare il file
$query = 'SELECT file FROM data WHERE id = '.$_GET['id'];
$risultato = mysql_query($query) or die('Query non valida: ' . mysql_error());
$tmp = mysql_fetch_array($risultato);
// invio una intestazione contenente il tipo MIME
header("Content-Type: application/octet-stream");
header("Content-Disposition: attachment; filename=\"$tmp[titolo]\"");
// invio il contenuto del file
echo $file;
?>