laravel自带提供下载功能,在route层,具体可以参考文档的文件下载。
本来想采用php下载,但由于暂时无法熟练运用header,所以改用js调用route下载,下面是我的实例。
laravelapp\routes\web.php
Route::get('download',function(){
return response()->download(realpath(base_path('public')).'/tourist.xlsx', 'tourist.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);
}
</script>
说明:
- 请确保你提供下载的文件存在。
- realpath(base_path('public')).'/tourist.xlsx'是一个参数,当然可以用绝对路径如:C:\xampp\htdocs\laravelapp\public\tourist.xlsx
- base_path 提供了相对路径的可行性,方便移植。
- 一开始当然先直接访问地址看能不能下载,如http://localhost:100/download ,可以下载再用js调用。
- 如果你遇到以下的错误,那么是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页面可以用以下代码调出。
Route::get('download',function(){
phpinfo();
//return response()->download(realpath(base_path('public')).'/tourist.xlsx', 'tourist.xlsx');
});
- 如果你像我一样用chorme浏览器打开下载页面会马上消失,推荐换个浏览器试试,如火狐,我便是用火狐成功的。
-
如果你调出这个页面,恭喜你成功了!