Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/html/83.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
从SQL数据库中的php脚本保存到文件弹出窗口。。。没有临时文件_Php_Html_Sql - Fatal编程技术网

从SQL数据库中的php脚本保存到文件弹出窗口。。。没有临时文件

从SQL数据库中的php脚本保存到文件弹出窗口。。。没有临时文件,php,html,sql,Php,Html,Sql,我有一个一般性的问题,不知道如何去实施它 我想创建一个链接,允许用户下载从SQL数据库生成的文件。例如,用户在HTML表单上输入ID,单击ok,就会出现“保存到文件”弹出窗口。文件中的数据将来自数据库 我通过php将文件保存在服务器的tmp目录中,从而实现了这一点,但我希望避免创建文件,即使是临时文件 谢谢您只需将文件“传递”给用户,响应PHP脚本就会将其头更新为文件类型 下面是doc@php.net中的一个函数: <?php function downloadFile( $fullPat

我有一个一般性的问题,不知道如何去实施它

我想创建一个链接,允许用户下载从SQL数据库生成的文件。例如,用户在HTML表单上输入ID,单击ok,就会出现“保存到文件”弹出窗口。文件中的数据将来自数据库

我通过php将文件保存在服务器的tmp目录中,从而实现了这一点,但我希望避免创建文件,即使是临时文件


谢谢

您只需将文件“传递”给用户,响应PHP脚本就会将其头更新为文件类型

下面是doc@php.net中的一个函数:

<?php
function downloadFile( $fullPath ){

  // Must be fresh start
  if( headers_sent() )
    die('Headers Sent');

  // Required for some browsers
  if(ini_get('zlib.output_compression'))
    ini_set('zlib.output_compression', 'Off');

  // File Exists?
  if( file_exists($fullPath) ){

    // Parse Info / Get Extension
    $fsize = filesize($fullPath);
    $path_parts = pathinfo($fullPath);
    $ext = strtolower($path_parts["extension"]);

    // Determine Content Type
    switch ($ext) {
      case "pdf": $ctype="application/pdf"; break;
      case "exe": $ctype="application/octet-stream"; break;
      case "zip": $ctype="application/zip"; break;
      case "doc": $ctype="application/msword"; break;
      case "xls": $ctype="application/vnd.ms-excel"; break;
      case "ppt": $ctype="application/vnd.ms-powerpoint"; break;
      case "gif": $ctype="image/gif"; break;
      case "png": $ctype="image/png"; break;
      case "jpeg":
      case "jpg": $ctype="image/jpg"; break;
      default: $ctype="application/force-download";
    }

    header("Pragma: public"); // required
    header("Expires: 0");
    header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
    header("Cache-Control: private",false); // required for certain browsers
    header("Content-Type: $ctype");
    header("Content-Disposition: attachment; filename=\"".basename($fullPath)."\";" );
    header("Content-Transfer-Encoding: binary");
    header("Content-Length: ".$fsize);
    ob_clean();
    flush();
    readfile( $fullPath );

  } else
    die('File Not Found');

}
?>


在上面的示例中,您需要修改它,以便只传回您拥有的数据,上面的示例是针对文件的(来自您的示例,如/tmp)

由于您当前正在保存一个临时文件作为过程的一部分,我假设您正在做的是从数据库中读取一个BLOB,对吗?不从数据库中保存的链接加载文件

在本例中,我猜您将BLOB放入一个变量中,并使用
file\u put\u contents()
将其保存到tmp目录中。然后
readfile()
将其发送到浏览器

如果是这种情况,那么您实际上可以完全跳过文件写入,只需将BLOB直接返回到浏览器

您只需要事先发送适当的标题。 使用
标题(“内容配置:附件;文件名:something.ext”)就足够下载了。您还可以发送文件的MIME类型,例如。
标题(“内容类型:application/pdf”)

您还必须记住,某些文件类型默认情况下是在浏览器中打开的。因此,如果发送带有pdf MIME类型的标题而不同时发送内容处置标题,用户将在浏览器中看到pdf,而不会被提示下载

编辑:仅举一个完整的示例,假设您使用的是mysql

$results = mysql_query($query);
while($row = mysql_fetch_array($results)) {
  $fileContent = $row['file'];
  $filename = $row['name']
  /* Get MIME type assuming that has 
     been saved with the file in the database
  */
  $mimeType = $row['type'];
}

// optional send mime type header
header("Content-type: $mimeType");

header("Content-disposition: attachment; filename = $filename");
echo $fileContent;

什么数据库?如何生成?如果不知道其中任何一个,你的问题就无法得到回答。