ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
基本: response()->download()
Laravel ではローカルファイルパスを指定するだけでブラウザダウンロードを発生させられます:
public function download() {
$filePath = public_path('exports/data.csv');
return response()->download($filePath);
// Content-Type / Content-Disposition は自動設定される
}
ファイル名を変更
サーバ上のファイル名と異なる名前でダウンロードさせたい場合:
$filePath = storage_path('app/internal_export_20240101_uuid.csv');
return response()->download($filePath, 'ユーザーデータ.csv');
// → ブラウザでは「ユーザーデータ.csv」として保存される
カスタムヘッダ付き
$headers = [
'Content-Type' => 'text/csv; charset=UTF-8',
'X-Custom-Header' => 'value',
];
return response()->download($filePath, 'data.csv', $headers);
送信後に一時ファイルを削除
一時ファイルを生成してダウンロードさせる場合、送信後に自動削除すると安全:
$tmpPath = storage_path('app/tmp_' . uniqid() . '.csv');
file_put_contents($tmpPath, $csvContent);
return response()
->download($tmpPath, 'export.csv')
->deleteFileAfterSend(true); // ← 送信後に削除
メモリ上のデータをダウンロード: streamDownload
大きな CSV を生成しながら同時にダウンロードさせたい(メモリに全部置きたくない)場合:
return response()->streamDownload(function () {
$handle = fopen('php://output', 'w');
// BOM 付き UTF-8(Excel 文字化け対策)
fwrite($handle, "\xEF\xBB\xBF");
// ヘッダ行
fputcsv($handle, ['id', 'name', 'email']);
// 大量データを 1 行ずつ書き出し(メモリ消費を抑える)
foreach (User::cursor() as $user) {
fputcsv($handle, [$user->id, $user->name, $user->email]);
}
fclose($handle);
}, 'users.csv', [
'Content-Type' => 'text/csv; charset=UTF-8',
]);
クラウドストレージ (S3 等) からダウンロード
S3 や FTP に置いたファイルを直接ダウンロードさせる:
use Illuminate\Support\Facades\Storage;
// S3 上のファイルを取得してダウンロード
return Storage::disk('s3')->download('exports/2024/data.csv', 'ユーザーデータ.csv');
// 一時的な公開 URL(プリサインド URL)を発行してリダイレクト
$url = Storage::disk('s3')->temporaryUrl(
'exports/2024/data.csv',
now()->addMinutes(5)
);
return redirect($url); // ブラウザが直接 S3 から取得
ブラウザ表示 (download ではなく view)
PDF や画像を「ダウンロード」ではなく「ブラウザ内で表示」させたい場合:
// inline = ブラウザ内表示、attachment = ダウンロード
return response()->file($filePath, [
'Content-Type' => 'application/pdf',
'Content-Disposition' => 'inline; filename="document.pdf"',
]);
// Storage 経由
return Storage::response('path/to/file.pdf'); // inline
return Storage::download('path/to/file.pdf'); // attachment
大容量ファイルの注意
| 問題 | 対処 |
|---|---|
| PHP のメモリ上限超過 | php.ini の memory_limit を上げる、または streamDownload を使う |
| 実行時間超過 (max_execution_time) | set_time_limit(0) をコントローラ先頭で実行 |
| Web サーバのバッファサイズ | Nginx の fastcgi_buffering off / Apache の SendBufferSize |
| セッションロック | ダウンロード中に他のリクエストが固まる → session()->save() で先にセッション解放 |
| レンジリクエスト (Resume) | Laravel 標準はサポート限定的 → 大容量は S3 直接配信を推奨 |
セキュリティ
- ファイルパスのバリデーション必須: ユーザー入力でファイル名を受け取る場合、
basename()とrealpath()でパストラバーサル防止 - 権限チェック: ダウンロードしてよいユーザーかどうかを Policy / Gate で確認
- Web ルート外に保存:
storage/app/やstorage/app/private/に置き、コントローラ経由でのみ配信 - ファイル拡張子と Content-Type: 実体と異なる拡張子だとブラウザが攻撃を許可してしまうリスク
サンプル: 認証済みユーザー専用ダウンロード
public function download(Order $order) {
// 認可チェック
$this->authorize('view', $order);
$path = $order->invoice_path;
if (!Storage::exists($path)) {
abort(404);
}
return Storage::download($path, "invoice_{$order->id}.pdf");
}
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- インストールと設定
- クイックスタート & チュートリアル(初心者向け)
- クイックスタート & チュートリアル(中級者向け)
- ルーティング
- Bladeテンプレート(ビュー/レイアウト)
- コントローラー
- マイグレーションとテーブル定義
- データベースの設定
- Eloquentモデル (ORM)
- SQLとクエリビルダー
- バリデーション
- .envファイルの設定値へのアクセス
- 動作環境による分岐処理
- configフォルダ配下の設定値へのアクセス
- assetヘルパーを利用したpublicフォルダへのアクセス
- storageフォルダへのアクセス
- アプリケーション名の変更
- メンテナンス
- ログイン画面(認証システム)の作成
- ログインの必須化
- ログインユーザー情報の取得
- ルートの認証化
- 本番サーバーへのデプロイ方法
- 多言語化
- csrf_field
- ファイルのダウンロード
- CSVのアップロードおよび読み込み(maatwebsite/excel)
- ページタイトルの設定
- コマンド一覧
- エラー一覧
- SQLの実行ログ出力方法
- キャッシュのクリア
- Selectの結果の最初もしくは最後に任意の値を追加する方法
- ajaxでPOST通信する際の注意点
- ソーシャルログインの実装
- セッション情報の確認
- ログイン、ユーザー登録、パスワードリセット後のリダイレクト先の変更方法
- redirectやreturn viewにメッセージを付与する方法
- クッキー(cookie)の設定と取得
- クラスの再読み込み
- csrfの有効時間を変更する方法
- ViewComposerを用いてviewに共通の値を付与する方法
- View::shareを用いて共通の値を各ビューに渡す方法
- ミドルウェアを用いた処理の共通化
- Middleware内でAuth::check()などを使用する方法
- Controller以外でリダイレクトする方法
- セッションの値の取得/保存/更新/削除
- $requestの値を変更する方法
- 常時SSL化
- ページング(ページネーション)をする方法
- vue.jsとの連携
- Vue.jsと連携するSPA実行環境構築
- .envの値をvue.jsで参照する方法
- vue.jsを本番環境にリリースする方法
- could not find driver(Windows, MySQL編)
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?