ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
.htaccess の基本
Apache HTTP Server でディレクトリごとに設定を上書きできる仕組みです。配置したディレクトリと配下に効果が及びます。サーバ全体の設定 (httpd.conf) を書き換えなくて済むのが利点。
有効化(AllowOverride)
# /etc/apache2/apache2.conf または /etc/httpd/conf/httpd.conf
<Directory /var/www/html>
AllowOverride All # ★ これが None だと .htaccess 無視
Require all granted
</Directory>
# 設定後リロード
# sudo systemctl reload apache2
# sudo systemctl reload httpd
URL リライト (RewriteEngine)
# /var/www/html/.htaccess
RewriteEngine On
# 1. すべての URL を index.php に転送(フレームワーク前提:Laravel/CodeIgniter 等)
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php [L,QSA]
# 2. /old → /new (恒久リダイレクト)
RewriteRule ^old/(.*)$ /new/$1 [R=301,L]
# 3. www あり → www なし統一
RewriteCond %{HTTP_HOST} ^www\.example\.com$ [NC]
RewriteRule ^(.*)$ https://example.com/$1 [R=301,L]
# 4. HTTP → HTTPS 強制
RewriteCond %{HTTPS} off
RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
# 5. クエリ文字列で振り分け
RewriteCond %{QUERY_STRING} ^id=(\d+)$
RewriteRule ^show\.php$ /post/%1? [R=301,L]
リダイレクト (mod_alias)
# 301 恒久リダイレクト
Redirect 301 /old-page /new-page
Redirect 301 /docs https://docs.example.com
# 302 一時リダイレクト
Redirect 302 /campaign /landing
# ディレクトリ全体
RedirectMatch 301 ^/blog/(.*)$ https://example.com/articles/$1
Basic 認証
# .htaccess
AuthType Basic
AuthName "Restricted Area" # ダイアログに表示される名称
AuthUserFile /etc/apache2/.htpasswd # ★ Web 公開外に置く
Require valid-user
# 特定ユーザだけ
Require user alice bob
# グループで管理
AuthGroupFile /etc/apache2/.htgroup
Require group admins
パスワードファイル作成:
# 新規作成(-c)
sudo htpasswd -c /etc/apache2/.htpasswd alice
# New password: ...
# Re-type new password: ...
# ユーザ追加(-c 無し)
sudo htpasswd /etc/apache2/.htpasswd bob
# 削除
sudo htpasswd -D /etc/apache2/.htpasswd bob
# 中身確認
cat /etc/apache2/.htpasswd
# alice:$apr1$xyz...
IP アドレス制限
# Apache 2.4+ 構文
# 特定 IP のみ許可
Require ip 192.168.1.0/24
Require ip 203.0.113.5
# 特定 IP のみ拒否(その他許可)
<RequireAll>
Require all granted
Require not ip 203.0.113.99
Require not ip 10.0.0.0/8
</RequireAll>
# 認証 + IP のいずれかで OK
<RequireAny>
Require ip 192.168.1.0/24
Require valid-user
</RequireAny>
# Apache 2.2 以前(古い記法、混在環境注意)
Order Deny,Allow
Deny from all
Allow from 192.168.1
ディレクトリ一覧の無効化
# index.html が無いディレクトリで一覧表示されるのを防ぐ
Options -Indexes
# シンボリックリンクも禁止したい
Options -Indexes -FollowSymLinks
# CGI 実行禁止
Options -ExecCGI
# .htaccess を無効化(サーバ管理者用)
AllowOverride None
特定ファイル / 拡張子の保護
# .env / .git / .htaccess 自体を Web からアクセス不可に
<FilesMatch "^\.">
Require all denied
</FilesMatch>
<Files ".env">
Require all denied
</Files>
<Files "composer.json">
Require all denied
</Files>
# 拡張子で
<FilesMatch "\.(sql|log|bak|swp|sh|env)$">
Require all denied
</FilesMatch>
# ディレクトリ単位
<Directory "/var/www/html/storage">
Require all denied
</Directory>
キャッシュ / 圧縮
# 静的ファイルのキャッシュヘッダ
<IfModule mod_expires.c>
ExpiresActive On
ExpiresByType image/jpeg "access plus 1 month"
ExpiresByType image/png "access plus 1 month"
ExpiresByType text/css "access plus 1 week"
ExpiresByType application/javascript "access plus 1 week"
ExpiresByType text/html "access plus 5 minutes"
</IfModule>
# gzip 圧縮
<IfModule mod_deflate.c>
AddOutputFilterByType DEFLATE text/html text/css application/javascript application/json text/xml
</IfModule>
# Brotli (mod_brotli 必要)
<IfModule mod_brotli.c>
AddOutputFilterByType BROTLI_COMPRESS text/html text/css application/javascript
</IfModule>
セキュリティヘッダ
<IfModule mod_headers.c>
Header always set Strict-Transport-Security "max-age=31536000; includeSubDomains"
Header always set X-Frame-Options "SAMEORIGIN"
Header always set X-Content-Type-Options "nosniff"
Header always set Referrer-Policy "strict-origin-when-cross-origin"
Header always set Permissions-Policy "geolocation=(), microphone=()"
Header always unset X-Powered-By
# CSP(厳密化したい場合)
Header always set Content-Security-Policy "default-src 'self'; script-src 'self' 'unsafe-inline'"
</IfModule>
カスタムエラーページ
ErrorDocument 404 /errors/404.html
ErrorDocument 403 /errors/403.html
ErrorDocument 500 /errors/500.html
ErrorDocument 503 /maintenance.html
Laravel 用 .htaccess 標準
# Laravel public/.htaccess(公式デフォルト)
<IfModule mod_rewrite.c>
<IfModule mod_negotiation.c>
Options -MultiViews -Indexes
</IfModule>
RewriteEngine On
# Authorization ヘッダの引き継ぎ
RewriteCond %{HTTP:Authorization} .
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
# /index.php へリダイレクトする末尾スラッシュ
RewriteRule ^(.*)/$ /$1 [L,R=301]
# 存在しないファイル / ディレクトリは index.php へ
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^ index.php [L]
</IfModule>
Nginx での同等設定
Nginx には .htaccess の概念がありません。すべて server / location ブロックで書きます:
server {
listen 80;
server_name example.com;
# HTTPS 強制
return 301 https://$host$request_uri;
}
server {
listen 443 ssl http2;
server_name example.com;
root /var/www/html/public;
index index.php;
# 全リクエストを index.php へ(Laravel)
location / {
try_files $uri $uri/ /index.php?$query_string;
}
# ディレクトリ一覧 OFF
autoindex off;
# 隠しファイル拒否
location ~ /\. {
deny all;
}
# Basic 認証
location /admin {
auth_basic "Restricted";
auth_basic_user_file /etc/nginx/.htpasswd;
}
# PHP
location ~ \.php$ {
fastcgi_pass unix:/run/php/php8.3-fpm.sock;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
}
デバッグ: 反映されているか確認
# 構文チェック
sudo apachectl configtest
# モジュール確認
apachectl -M | grep rewrite # rewrite_module (shared) と出れば OK
apachectl -M | grep headers
apachectl -M | grep auth_basic
# 有効化
sudo a2enmod rewrite headers
sudo systemctl restart apache2
# .htaccess が読まれているか
echo "Deny from all" >> .htaccess # 一時的に
# → 全リクエストが 403 になれば反映されている
FAQ
Q: .htaccess の変更を即時反映するには?
A: 不要。配置・更新と同時に Apache が読み込みます。サーバ再起動は不要です。
Q: .htaccess を使うと遅い?
A: ディレクトリ階層をたどるたびに読み込むので性能を気にする本番では httpd.conf に書くのが定石です。
Q: 反映されない
A: ① AllowOverride All 確認 ② a2enmod rewrite ③ Apache 再起動 ④ .htaccess の文法エラー(error.log 参照)。
📚 関連: ファイル形式・拡張子セクション — 主要なファイル拡張子・形式を体系的に解説。conf(.conf) / Web・データ・設定(カテゴリ)
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
人気ページ
- 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アノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?