ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
asset() の基本
asset() は public/ ディレクトリ内のファイルへの URL を生成するヘルパー関数です。Blade テンプレートで CSS / JS / 画像を読み込むときの定番です。
{{-- 例: APP_URL=http://example.com の場合 --}}
{{-- → http://example.com/css/app.css --}}
{{-- → http://example.com/js/app.js --}}
{{-- → http://example.com/images/logo.png --}}
ファイル配置の前提
プロジェクトルート/
├── app/
├── public/ ← Web 公開ルート(DocumentRoot)
│ ├── index.php
│ ├── favicon.ico
│ ├── css/
│ │ └── app.css ← asset('css/app.css') で参照
│ ├── js/
│ │ └── app.js
│ └── images/
│ └── logo.png
├── resources/ ← 元ソース。Mix/Vite でビルドして public/ へ
└── ...
URL の組み立てロジック
asset() が返す URL は次の優先順位で決まります:
config('app.asset_url')(ASSET_URL環境変数)— CDN 等を別ホストにしたい場合config('app.url')(APP_URL環境変数)- リクエストの
scheme://host
// 内部実装イメージ (簡略)
function asset(string $path, ?bool $secure = null): string
{
return app('url')->asset($path, $secure);
}
// .env 例
APP_URL=https://example.com
ASSET_URL=https://cdn.example.com // ← 設定すると asset() がこちらを優先
secure_asset() による HTTPS 強制
{{-- 常に https:// で出力したい --}}
{{-- 第 2 引数で個別指定も可 --}}
本番環境では AppServiceProvider::boot() で一括強制するのが楽です:
use Illuminate\Support\Facades\URL;
public function boot()
{
if ($this->app->environment('production')) {
URL::forceScheme('https');
}
}
asset / url / route の違い
| ヘルパー | 用途 | 出力例 |
|---|---|---|
asset('css/app.css') | 静的ファイル(public/) | https://example.com/css/app.css |
url('/users') | アプリの任意 URL | https://example.com/users |
route('users.show', 1) | 名前付きルート | https://example.com/users/1 |
action([UserController::class, 'show'], 1) | コントローラから生成 | https://example.com/users/1 |
キャッシュバスティングが必要な場面
asset('css/app.css') はそのまま /css/app.css を出力するため、ブラウザがキャッシュした古い CSS を読み続ける問題が起きます。デプロイのたびに新しい URL にしたい場合は Mix / Vite を使います。
{{-- Laravel Mix (mix-manifest.json を参照) --}}
{{-- → /css/app.css?id=8a1b3c... のようにハッシュ付き --}}
{{-- Vite (Laravel 9.19+) --}}
@vite(['resources/css/app.css', 'resources/js/app.js'])
{{-- →
--}}
CDN 配信のための ASSET_URL 設定
# .env で別ホストを指定
APP_URL=https://example.com
ASSET_URL=https://d1xxxxxx.cloudfront.net
# Blade での出力結果
# asset('images/logo.png')
# → https://d1xxxxxx.cloudfront.net/images/logo.png
# url('/users') はアプリ側 (example.com) のまま
# → https://example.com/users
よくあるトラブル
| 症状 | 原因 / 対処 |
|---|---|
| 本番で http:// になる | APP_URL が https:// になっていない、または URL::forceScheme('https') 未設定 |
ローカルでドメインが localhost 以外になる | APP_URL を上書き。config:clear 必須 |
| サブディレクトリで動かしたら 404 | APP_URL に /myapp を含める。例: https://example.com/myapp |
| storage/app/public が見えない | php artisan storage:link でシンボリックリンク作成 |
storage と asset の連携
# storage/app/public → public/storage のシンボリックリンクを張る
php artisan storage:link{{-- アップロード画像を表示 --}}
{{-- または Storage ファサード --}}
 }})
FAQ
Q: asset() の出力をすべて HTTPS にしたい
A: APP_URL=https://... に加え、AppServiceProvider で URL::forceScheme('https')。リバプロ配下なら TrustProxies ミドルウェアも設定。
Q: バージョン文字列を付けたい(?v=1.2)
A: 簡易にやるなら asset('css/app.css') . '?v=' . config('app.version')。本格的には Mix / Vite を使用。
Q: 画像 URL を Blade 内で組み立てるベストプラクティス
A: アップロード画像なら Storage::url()、固定アセットなら asset()、CDN 経由なら ASSET_URL + asset()。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?