質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

1回答

687閲覧

Laravel5.5 CSVダウンロード

AMK

総合スコア765

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2017/12/08 07:48

編集2017/12/08 08:03

このページのほぼコピペで
https://programmer-jobs.blogspot.jp/2017/04/laravel-5-4-csv-download.html
TESTで作ったサイトでは動いたのですが
今回作ったサイトでは動かず原因特定が私では難しいのでヘルプして頂きたいです。

たぶん解る人なら10分も掛からない作業かと思います。

テーブル名
customers

controller名
CustomersController

php

1//CustomersController.php 2namespace App\Http\Controllers; 3 4use Illuminate\Http\Request; 5use DB; 6use Carbon\Carbon; 7use \App\User; 8class CustomersController extends Controller 9{ 10 public function __construct() 11 { 12 $this->middleware('auth')->except(['index', 'confirm','complete']); 13 } 14 15//一部アクション省略 16 17 //CSV 18 public function csvDownload() 19 { 20 $headers = array( 21 "Content-type" => "text/csv", 22 "Content-Disposition" => "attachment; filename=file.csv", 23 "Pragma" => "no-cache", 24 "Cache-Control" => "must-revalidate, post-check=0, pre-check=0", 25 "Expires" => "0" 26 ); 27 28 $callback = function() { 29 $handle = fopen('php://output', 'w'); 30 31 $columns = [ 32 'id', 33 'name', 34 'sex', 35 ] ; 36 mb_convert_variables('SJIS-win', 'UTF-8', $columns); 37 38 fputcsv($handle, $columns); 39 40 $customers = Customers::all(); 41 foreach ($customers as $customer) { 42 $csv = [ 43 $customer->id, 44 $customer->name, 45 $customer->sex, 46 ] ; 47 mb_convert_variables('SJIS-win', 'UTF-8', $csv); 48 fputcsv($handle, $csv); 49 } 50 51 fclose($handle); 52 }; 53 return response()->stream($callback, 200, $headers); 54 }

php

1//web.php 2Route::get('/', 'CustomersController@index'); 3Route::post('/','CustomersController@confirm'); 4Route::post('/complete','CustomersController@complete'); 5 6Auth::routes(); 7Route::get('/dl', 'CustomersController@csvDownload'); 8Route::get('/home', 'HomeController@index')->name('home');

php

1//home.blade.php 2@extends('layouts.app') 3 4@section('content') 5<div class="container"> 6 <div class="row"> 7 <div class="col-md-8 col-md-offset-2"> 8 <div class="panel panel-default"> 9 <div class="panel-heading">管理メニュー</div> 10 11 <div class="panel-body"> 12 @if (session('status')) 13 <div class="alert alert-success"> 14 {{ session('status') }} 15 </div> 16 @endif 17 18 <ul> 19 <li><a href="/dl">CsvDownload</a></li> 20 </ul> 21 </div> 22 </div> 23 </div> 24 </div> 25</div> 26@endsection 27 28コード

症状としては、
このサイトにアクセスできません
と出て、DLされない。

エラーログを見ると
$customers = Customers::all();
でエラーが出ている

php

1//エラーログ 2[2017-12-08 16:42:10] local.ERROR: Class 'App\Http\Controllers\Customers' not found {"userId":2,"email":"beruzea@gmail.com","exception":"[object] (Symfony\Component\Debug\Exception\FatalThrowableError(code: 0): Class 'App\Http\Controllers\Customers' not found at /home/kusanagi/laravel/app/Http/Controllers/CustomersController.php:131) 3[stacktrace] 4#0 [internal function]: App\Http\Controllers\CustomersController->App\Http\Controllers\{closure}() 5#1 /home/kusanagi/laravel/vendor/symfony/http-foundation/StreamedResponse.php(114): call_user_func(Object(Closure)) 6#2 /home/kusanagi/laravel/vendor/symfony/http-foundation/Response.php(371): Symfony\Component\HttpFoundation\StreamedResponse->sendContent() 7#3 /home/kusanagi/laravel/DocumentRoot/index.php(58): Symfony\Component\HttpFoundation\Response->send() 8#4 {main} 9"} 10

自分なりにエラーログを見てcontrollerを見失っている???と思い
use App\Customers;を追加してみたり自分なりには、色々と試しては見たのですが
お手上げです。

ご教示お願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

まずコントローラーに

namespace App\Http\Controllers; use App\Customers;

は追加しておいた方が良さそうですね。あと、Customersモデルはそもそも存在してますか?

【追記】
モデルを作っていないなら、エラーが出るのは当然かと。存在しないものをuseしても意味ないです。

Customers.php <?php namespace App; use Illuminate\Database\Eloquent\Model; class Customers extends Model { // protected $table = 'テーブル名'; protected $primaryKey = 'キー'; public $timestamps = false; }

まずはAppフォルダ内にCustomers.phpというモデルを作ってください。

投稿2017/12/08 07:52

編集2017/12/08 08:12
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

AMK

2017/12/08 07:59

すみません、コードにnamespace App\Http\Controllers;をコピペ抜けてました。 元々namespace App\Http\Controllers;は、入力されていました。
退会済みユーザー

退会済みユーザー

2017/12/08 08:02

こちらも回答修正させていただきましたので、確認してもらえますか?
AMK

2017/12/08 08:05

use App\Customers; 追加でもダメでした モデルは今回作成していません。
退会済みユーザー

退会済みユーザー

2017/12/08 08:12

モデルがないなら追加しても意味ないですね。回答を更新したので試してみてください。
AMK

2017/12/08 08:18

いけました!! ありがとうございます。!!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問