zoukankan      html  css  js  c++  java
  • php文件下载

        本次做的小项目应用了文件下载功能,文件上传是放在a标签里的,所以要刷新页面下载,也就是说不能用post传值的方法来进行文件下载,下载不能是本地下载,需要服务器下载,有时候方法不对,如果下载的是txt文本,就会把文本输出到浏览器上,代码如下所示
     
    index.php文件里的内容如下图所示:
    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    </head>
    <body>
        <a href="http://localhost/text/1.txt">点击下载文件</a>     //如果是.txt的文本,就会输出到浏览器上
        <a href="index.php">11111111111111</a>    //地址这样写可以
        <a href="http://localhost/text/download.php" id="aa">222222</a>   //地址这样写也可以
    </body>
    </html>
    目录文件夹如下图所示:
     
    download.php里的内容如下图所示:
    <?php 
        header("Content-type:text/html;charset=utf-8"); 
        // $file_name="cookie.jpg"; 
        $file_name="1.txt"; 
        //用以解决中文不能显示出来的问题 
        $file_name=iconv("utf-8","gb2312",$file_name); 
        $file_sub_path=dirname(__FILE__); 
        $file_path=$file_sub_path.'/'.$file_name; 
        //首先要判断给定的文件存在与否 
        if(!file_exists($file_path)){ 
            echo "没有该文件文件"; 
            return ; 
        } 
        $fp=fopen($file_path,"r"); 
        $file_size=filesize($file_path); 
        //下载文件需要用到的头 
        Header("Content-type: application/octet-stream"); //通过这句代码客户端浏览器就能知道服务端返回的文件形式 
        Header("Accept-Ranges: bytes"); //告诉客户端浏览器返回的文件大小是按照字节进行计算的 
        Header("Accept-Length:".$file_size); //告诉浏览器返回的文件大小 
        Header("Content-Disposition: attachment; filename=".$file_name); //告诉浏览器返回的文件的名称 
        $buffer=1024; 
        $file_count=0; 
        //向浏览器返回数据 
        while(!feof($fp) && $file_count<$file_size){ 
            $file_con=fread($fp,$buffer); 
            $file_count+=$buffer; 
            echo $file_con; 
        } 
        fclose($fp); 
    ?>
     
     
     
     
     
     
     
     
     
  • 相关阅读:
    关于有序查找的随笔
    Spring框架(一) 创建bean
    Linux常用命令
    Spring框架(二) bean的歧义性
    java实现图片文字识别的两种方法
    分享基于分布式Http长连接框架代码模型
    分享基于分布式Http长连接框架设计模型
    无限树Jquery插件zTree的使用方法
    分享基于分布式Http长连接框架
    使用vs编译事件来动态发布配置文件
  • 原文地址:https://www.cnblogs.com/liuwanqiu/p/5532566.html
Copyright © 2011-2022 走看看