laravel-excel无法使用带有图像的刀片导出xls文件

时间:2014-09-30 08:39:32

标签: php html excel laravel laravel-excel

对不起, 我想使用laravel-excel导出我的报告。 这是控制器:

public function getExcelfile(){
        $users = UserService::findAllPublic();
        $total = UserService::count();
        $total_with_photo = UserService::countWithPhoto();
        Excel::create('excelfile', function($excel) use ($users, $total, $total_with_photo) {
            $excel->sheet('Excel', function($sheet) use ($users, $total, $total_with_photo) {
                $sheet->loadView('report.excel')->with("users", $users)->with("total", $total)->with("total_with_photo", $total_with_photo);
            });
        })->export('xls');
    }

这是位于报告文件夹的excel.blade.php:

<html> <body> Total Registered User : {{$total}} Total Registered User With Photo : {{$total_with_photo}} <h1>Data User</h1> @if(!empty($users)) <table class="table table-striped table-bordered">
    <thead>
    <tr>
        <th>ID</th>
        <th>Photo</th>
        <th>Nama</th>
        <th>Struck</th>
        <th>Email</th>
        <th>Phone</th>
        <th>FB ID</th>
        <th>Timestamp</th>
        <th>Publish</th>
    </tr>
    </thead>
    @foreach ($users as $row)
    <tr>
        <td>{{$row->id}}</td>
        <td><img src="{{URL::asset('assets/images/upload/' . $row->photo)}}" width="200px"/></td>
        <td>{{$row->nama}}</td>
        <td>{{$row->struck}}</td>
        <td>{{$row->email}}</td>
        <td>{{$row->phone}}</td>
        <td>{{$row->fbid}}</td>
        <td>{{$row->timestamp}}</td>
        <td>{{$row->publish}}</td>
    </tr>
    @endforeach </table> @endif </body> </html>

然后出现此错误:

PHPExcel_Exception

File http://myserver.com/projectname/public/assets/images/upload/DSCN1164.jpg not found!

当我尝试在浏览器中访问该文件时,该文件存在。

1 个答案:

答案 0 :(得分:4)

而不是:

<img src="{{URL::asset('assets/images/upload/' . $row->photo)}}"

你应该使用:

<img src="assets/images/upload/{{{ $row->photo }}}"

当然假设它是正确的路径