ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
.env とは
.env は環境固有の設定値(DB パスワード、API キー、メールサーバ等)を、コードリポジトリに含めずに保存するためのファイルです。本番・ステージング・ローカルで値を切り替える際に使用します。
# .env の典型例
APP_NAME=MyApp
APP_ENV=production
APP_DEBUG=false
APP_URL=https://example.com
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=myapp
DB_USERNAME=app_user
DB_PASSWORD=s3cret-passw0rd
MAIL_MAILER=smtp
MAIL_HOST=smtp.gmail.com
MAIL_PORT=587
Laravel: env() と config() の使い分け(重要)
Laravel で 最も多い事故がここです:
// ❌ アンチパターン: コード中で env() を直接使う
class UserController extends Controller {
public function index() {
$appName = env('APP_NAME'); // 本番で null になる!
return view('user.index', compact('appName'));
}
}
// ✅ 正解: config() ヘルパーで取得
class UserController extends Controller {
public function index() {
$appName = config('app.name'); // config:cache 後も動く
return view('user.index', compact('appName'));
}
}
理由: 本番で php artisan config:cache を実行すると、Laravel は config/*.php 配下を bootstrap/cache/config.php に 1 ファイル化します。このとき $_ENV はロードされなくなり、env() は null を返すようになります。一方 config() はキャッシュされた値を読むので問題なく動きます。
Laravel の正しいフロー
.env → config/*.php → config() で取得 の三段構成にします:
// 1) .env
STRIPE_SECRET_KEY=sk_live_xxxxx
STRIPE_WEBHOOK_SECRET=whsec_xxxxx
// 2) config/services.php
return [
'stripe' => [
'secret' => env('STRIPE_SECRET_KEY'), // ← config/ 内なら env() OK
'webhook' => env('STRIPE_WEBHOOK_SECRET'),
],
];
// 3) コード(Controller / Service / Job)
$secret = config('services.stripe.secret'); // ← ここは config() で
$webhookSecret = config('services.stripe.webhook');
env() ヘルパーの仕様
// 基本
env('APP_NAME'); // string|null
// デフォルト値
env('APP_DEBUG', false); // 未定義なら false
// 型変換(文字列リテラル)
env('APP_DEBUG'); // .env に APP_DEBUG=true → (bool) true
env('FOO'); // .env に FOO=null → (null) null
env('BAR'); // .env に BAR=empty → (string) ''
env('BAZ'); // .env に BAZ=(true) → (bool) true
// 値にスペース / 特殊文字を含めるならクォート
// .env
APP_NAME="My Cool App"
PASSWORD='p@ss"word'
本番デプロイの正しい手順
# 1) コード更新
git pull origin main
composer install --no-dev --optimize-autoloader
# 2) .env が正しいか確認
php artisan tinker
> config('database.connections.mysql.host')
# 値が表示されれば OK
# 3) 設定キャッシュを再生成(高速化)
php artisan config:cache
php artisan route:cache
php artisan view:cache
# .env を更新したら必ず
php artisan config:clear && php artisan config:cache
Node.js: dotenv パッケージ
npm install dotenv// app.js の先頭で 1 回だけ呼ぶ
require('dotenv').config();
// 以降は process.env で取得
console.log(process.env.DB_HOST);
console.log(process.env.STRIPE_SECRET_KEY);
// デフォルト値
const port = process.env.PORT || 3000;
// 型変換は自分でやる
const debug = process.env.DEBUG === 'true'; // 文字列 'true' → bool
const maxConn = parseInt(process.env.MAX_CONN || '10', 10);
// ES Modules 版
import 'dotenv/config';
import dotenv from 'dotenv';
dotenv.config({ path: '.env.production' });
PHP 単体: vlucas/phpdotenv
composer require vlucas/phpdotenvload();
// 取得(3 通り)
echo $_ENV['DB_HOST'];
echo $_SERVER['DB_HOST'];
echo getenv('DB_HOST');
// 必須キーの存在チェック
$dotenv->required(['DB_HOST', 'DB_USER', 'DB_PASS']);
// 型チェック
$dotenv->required('PORT')->isInteger();
$dotenv->required('APP_ENV')->allowedValues(['local', 'staging', 'production']);
Python: python-dotenv
pip install python-dotenvimport os
from dotenv import load_dotenv
load_dotenv() # カレントの .env を読む
db_host = os.getenv('DB_HOST')
db_port = int(os.getenv('DB_PORT', '5432'))
debug = os.getenv('DEBUG', 'False').lower() == 'true'
# Django なら settings.py で
# load_dotenv()
# SECRET_KEY = os.environ['SECRET_KEY']
.env を Git に含めないルール
# .gitignore
.env
.env.local
.env.*.local
# サンプルだけ共有
!.env.example
.env.example をリポジトリに置き、各開発者がコピーして使う運用が標準です:
cp .env.example .env
php artisan key:generate # Laravel: APP_KEY を生成
よくあるトラブル
| 症状 | 原因 | 対処 |
|---|---|---|
本番だけ env() が null | config:cache 実行済 | コードを config() に直す |
| .env を変えても反映されない | config キャッシュが古い | php artisan config:clear |
| 値にスペースを含めると壊れる | クォート無し | KEY="My Value" |
| 真偽値が文字列扱い | "true" リテラル | クォート無しで true と書く |
| artisan が boot で落ちる | .env が壊れている | php artisan tinker で確認 |
FAQ
Q: なぜ env() を直接使ってはいけないのか
A: config:cache 後の本番で null を返すから。「ローカルで動いて本番で死ぬ」最頻バグです。
Q: .env を暗号化したい
A: Laravel 9+ は php artisan env:encrypt / env:decrypt でファイル単位の暗号化に対応しています。
Q: 環境別に値を分けたい
A: .env.local / .env.staging / .env.production を作り、デプロイ時にコピー or シンボリックリンクで切り替えるのが一般的です。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?