WordPressでリダイレクト:『.htaccess』の書き方まとめ
『.htaccess』は変更する頻度が少ないので、変更する時に勉強して把握しても、一度変更してしまえばそれでおしまい!となって、次また変更するとなった時は、すっかり忘れてて一から勉強しなおし〜〜〜。なんてことが、ここ何回続いてるでしょうか。。
そうならないために『301リダイレクトでサイトのリニューアル(ドメインを変更)する!』や『[http] から [https] へ。常時SSL化対応』『URLの正規化:wwwあり、なしのドメインを統一する記述方法』といった記事にまとめてはいるのですが、それすら忘れてしまってて。。
ってことで、今回は以前書いた記事をより簡単にまとめて、『.htaccess』の書き方・ルールを書きたいと思います。
[www]はなし・[http]→[https]へリダイレクト(統一)する
wwwなしで統一する記述は3,4行目に、常時SSL化対応のための[http]から[https]へ統一する記述は6,7行目に定義したものが、以下の記述になります。
そのサイトのみに使える記述
RewriteEngine on RewriteCond %{HTTP_HOST} ^https://www.webdesign-abc\.com RewriteRule ^(.*)$ https://webdesign-abc.com/\ [R=301,L] RewriteCond %{HTTPS} !on RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
今までは『https://webdesign-abc.com』とアドレスを記述していたので、『Webデザイン ABC』のみにしかこの記述は使えませんでした。
この記述は間違いではないので、URLさえ変更すれば問題はないのですが、管理している別サイトに記述する際、いちいちアドレスを変更して記載しないといけません。ですので、どのサイトでも使えるように汎用版として記述したのが以下になります。
どのサイトでも使える記述(汎用版:コピペOK!)
RewriteEngine on RewriteCond %{HTTP_HOST} ^www\.(.*)$ [NC] RewriteRule ^(.*)$ https://%1/\ [R=301,L] RewriteCond %{HTTPS} !on RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
解説
1行目:RewriteEngine On
Rewrite機能を有効にします。
(Rewrite機能=アクセスのあったURLを、正規表現に書き換えてから処理をする機能。)
3行目:RewriteCond %{HTTP_HOST} ^www\.(.*)$ [NC]
RewriteRuleを実行するための条件を定義します。
%{HTTP_HOST}=ホスト名(簡単にはwwwを含んだアドレス)を取得
^=正規表現の行頭:「.htaccess」が設置されている場所から見たURL
\.=「.」が特別な意味を持たないように「\」を使用している
(.*)=任意の0文字以上の文字
$=正規表現の行末
[NC]=大文字小文字を区別しない
3行目の定義としては、wwwが付いていれば(このサイトであれば「www.webdesign-abc.com」であれば)、4行目の処理を行いますよ。ということになります。
4行目:RewriteRule ^(.*)$ https://%1/$1 [R=301,L]
RewriteCondの条件に当てはまった場合は、RewriteRuleを実行します。
R=301=「301リダイレクト」([R=permanent]も同じ意味)
L=RewriteCondの条件にあてはまったRewriteRuleはここで終わり
ここまでが『wwwなしで統一する記述』で、
ここからが『[http]から[https]へ統一する記述』です。
6行目:RewriteCond %{HTTPS} !on
!on=「!」は否定なので、onではない場合=「httpsでアクセスされていない場合」=offと同じ意味
7行目:RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
%{HTTP_HOST}%{REQUEST_URI}=ホスト名はそのままで[http]を[https]に変換する
ちなみにここは『[http] から [https] へ。常時SSL化対応』と『URLの正規化:wwwあり、なしのドメインを統一する記述方法』をまとめたものになりますね。
ページのリダイレクト
RewriteEngine on RewriteRule ^old.html$ https://webdesign-abc.com/new.html [L,R=301]
新しいURLは、httpsから始まる絶対パスで記述してください。
ディレクトリのリダイレクト
RewriteEngine on RewriteRule ^old(.*)$ /new$1 [L,R=301]
.*はあらゆる文字列で、()で囲むと後方の$1に代入されます。
メモ
『RewriteEngine on』は一度書けば毎回書かなくてもOKなので、ページとディレクトリのリダイレクトをまとめて行う場合は、
RewriteEngine on RewriteRule ^old.html$ https://webdesign-abc.com/new.html [L,R=301] RewriteEngine on RewriteRule ^old(.*)$ /new$1 [L,R=301]
ではなく、
RewriteEngine on RewriteRule ^old.html$ https://webdesign-abc.com/new.html [L,R=301] RewriteRule ^old(.*)$ /new$1 [L,R=301]
でOK!
まとめ
正直、完璧に把握しきれていない部分もあるのですが、とりあえずこれでよいかと思います。また修正なり追記事項がああれば、適宜修正・追記していきたいと思います。
Google AdS
関連記事
WordPressのメニューを、footer等用に作成して追加する方法
WorPressのデフォルトでは、gnavi(グローバルナビ)にメニューを追加し、表示させることはできますが、foote…
WordPressで “SyntaxHighlighter” を使って、ソースコードをキレイに書く方法
よくwebデザイナーさんやクリエイターさん、プログラマーさんたちの書いてるwebサイトを見たら、ソースコードを、 …
スマホ、携帯からタップ(クリック)で電話を発信する、htmlの記述方法 コピペでOK!!
スマホ等のタブレット、また携帯で、電話番号をタップ(クリック)して直接かけるhtmlの記述方法です。 …
WordPress:特定カテゴリで投稿を古い順に表示させる方法
Wordpressの投稿の表示は、デフォルトでは新しいものから表示されますよね。でも特定カテゴリーでは反対(投稿した順番…
WordPressのテスト(ステージング)環境を簡単に作る方法・注意点:XSERVER + All in On WP Migration
今まで企業サイトの管理等では、最初から環境が整っているところばかりだったので、開発・テスト・ステージング環境はあまり深く…