文件从数据库php下载错误

时间:2013-10-17 19:51:20

标签: php

我已经阅读了有关此主题的每个教程,但没有一个帮助解决我的问题。我不知道为什么,但是每当我点击下载按钮而不是下载图像文件时,我的代码只是给我一个html文件。

HTML:

<a href="getfile.php?id=1">Download Now</a>

PHP:

<?php
$id= $_GET['id'];
$con= mysqli_connect("localhost","root","","dbname");

    if (mysqli_connect_errno($con))
     {
        echo "<script type=\"text/javascript\">alert('Failed To connect to  MySQL: "+"mysqli_connect_error();"+"');</script>";
    }
    else
    {
        $sql = "SELECT * FROM users_files WHERE file_id = ".$id;
        $result = mysql_query($sql);
         $row_cnt = mysqli_num_rows($result);
         echo "<script type=\"text/javascript\">alert('".$row_cnt."');</script>";
        if(!$result || !mysql_num_rows($result)){
            echo "<script type=\"text/javascript\">alert('Invalid file chosen.');</script>";
            //echo '<script language="javascript" type="text/javascript" >';
        //echo ' window.location.assign("ViewMyFiles.php");';
        //echo '</script>';
        mysqli_close($con);
            }
            $curr_file = mysql_fetch_assoc($result);

            $size = $curr_file['file_size'];
            $type = $curr_file['file_type'];
            $name = $curr_file['file_name'];
            $content = $curr_file['file_content'];

            header("Content-length: ".$size."");
            header("Content-type: ".$type."");
            header('Content-Disposition: attachment; filename="'.$name.'"');
            readfile($content);
            $_SESSION['email']=$nemail;
            mysqli_close($con);
    }
?>

我将以上PHP文件命名为getfile.php,我的下载结果为getfile.htm

2 个答案:

答案 0 :(得分:1)

调试!

注释标题并查看真正获得客户端的内容。然后评论它们并检查浏览器开发控制台(标题+响应)。

您也容易受到SQL注入攻击。

答案 1 :(得分:0)

我认为您的标题是空白的,即使您必须通过显示您的文件名来检查文件扩展名,如:

echo "<script> alert('$name.$type'); </script>";

我认为这会对你有帮助