laravel实现下载文件

laravelapp\routes\web.php


Route::get('download',function(){
    return response()->download(realpath(base_path('public')).'/tourist.xlsx', 'tourist.xlsx');
});
<form action="" method="post" enctype="multipart/form-data">
 {{csrf_field()}}
 <div class="add_box"> <span onclick="downloadExcel()">模板下载</span> 
</div> 
</form>
//模板下载
   function downloadExcel(){
    //获取服务器地址
       var host = location.host;
       //把excel发送出来
       var url = "http://"+ host +"/admin/commodity/download";
       window.open(url);
   }
/*
 * @模板下载
 */
public function download(){
    return response()
        ->download(realpath(base_path('public')).'/goods.xlsx', 'goods.xlsx');
}
/*
 * @模板下载
 */
public function download(){
    return response()
        ->download(realpath(base_path('public')).'/goods.xlsx', "商品导入表".'.xlsx');
}

上面的是中文的下载方式,

>download(realpath(base_path('public')).'/goods.xlsx'==============>是路径

"商品导入表".'.xlsx'===================>是下载后的别名

laravelapp\resources\views\email\back.blade.php

<button onclick="downloadExcel()">Download Excel</button>

<script>
    function downloadExcel() {
        //获取服务器地址
        var host = location.host;

        //把excel发送出来
        var url = "http://"+ host +"/download";
        window.open(url);
    }

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

说明:

  1. 请确保你提供下载的文件存在。
  2. realpath(base_path('public')).'/tourist.xlsx'是一个参数,当然可以用绝对路径如:C:\xampp\htdocs\laravelapp\public\tourist.xlsx
  3. base_path 提供了相对路径的可行性,方便移植。
  4. 一开始当然先直接访问地址看能不能下载,如http://localhost:100/download ,可以下载再用js调用。
  5. 如果你遇到以下的错误,那么是php有一项服务没有打开。
    LogicException in MimeTypeGuesser.php line 135:
    Unable to guess the mime type as no guessers are available (Did you enable the php_fileinfo extension?)

    解决:
    去到php目录下找到php.ini文件,如C:\xampp\php\php.ini,找到 extension=php_fileinfo.dll,把前面的分号去掉,并重启一遍服务器,如:

    C:\xampp\htdocs\laravelapp>php -S localhost:100 -t public

    在phpinfo页面可以搜索fileinfo,看到下图,说明你成功开启了。

    phpinfo.php


    phpinfo页面可以用以下代码调出。

    Route::get('download',function(){
        phpinfo();
        //return response()->download(realpath(base_path('public')).'/tourist.xlsx', 'tourist.xlsx');
    });
  6. 如果你像我一样用chorme浏览器打开下载页面会马上消失,推荐换个浏览器试试,如火狐,我便是用火狐成功的。
  7. 如果你调出这个页面,恭喜你成功了!

    下载页面

参考:http://www.jianshu.com/p/e4f2770971ce

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值