スマホ・PCを判別してリダイレクトする方法まとめ

この記事にはプロモーションが含まれています

ウェブサイトでPC用ページとスマホ用ページが別々に存在する場合、ユーザーエージェントで振り分けるのが一般的です。

.htaccess , JavaScript , PHPでのスマホ・PCの条件分岐をまとめました。

ユーザーエージェント

iPhone[iPhone]が含まれていて[iPad]が含まれていない
Android[Android]か [Mobile]が含まれている
Windows Phone[Windows Phone]が含まれている
PCそれ以外

.htaccess で自動的に振り分ける方法

一番よく使います。

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{HTTP_USER_AGENT} (iPhone|Android.*Mobile|Windows.*Phone) [NC]
RewriteCond %{QUERY_STRING} !mode=pc
RewriteRule ^$ /sp/ [R,L]
</IfModule>

4行目のRewriteCond %{QUERY_STRING} !mode=pcは

?mode=pc

というパラメーターがURLに付与されていないときだけリダイレクトする
付与されている場合はリダイレクトしないという意味です。

スマホ用ページからPC用ページにリダイレクトする場合

使う機会はあまりないと思うが、検索結果でスマホ専用ページがPC用のページより上位に来ちゃったからスマホページにアクセスしたらPCページに飛ばしたいときなど

その場合、3行目を以下のように変更します

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{HTTP_USER_AGENT} !(iPod|iPhone|iPad|Android|Windows\ Phone) [NC]
RewriteCond %{QUERY_STRING} !mode=pc
RewriteRule ^$ /sp/ [R,L]
</IfModule>

JavaScript でスマホ用ページにリダイレクトする

JavaScriptでユーザーエージェントを判定して合致した場合はスマホ用URL「/sp/」へリダイレクトする方法です。

var ua = navigator.userAgent;

if ((ua.indexOf('iPhone') > 0 && ua.indexOf('iPad') == -1) || ua.indexOf('iPod') > 0 || (ua.indexOf('Android') > 0 && ua.indexOf('Mobile') > 0  )|| ua.indexOf('Windows Phone'))
	{
		location.href = '/sp/';
	}

indexOf()メソッドは、指定したキーワードの発見位置を返す。
発見できなければ「-1」を返すので、0より上であればキーワードが発見できたことになります。

iPadは「-1」で除外、Androidのタブレットも除外しています。

navigator.userAgentが「iPhone」だった場合

<script type="text/javascript">
if ((navigator.userAgent.indexOf('iPhone') > 0{
//iPhoneだったときの処理
}
</script>

navigator.userAgentがiPhoneじゃなかったとき

<script type="text/javascript">
if ((navigator.userAgent.indexOf('iPhone') == -1{
//iPhoneじゃなかったときの処理
}
</script>

PHPによるスマホ、PCの振り分け

PHPによる振り分けのメリットは、サーバーサイドで初回リクエスト時にデバイスを判定してリダイレクトするため効率的でJavaScriptが無効なデバイスやブラウザでも動作することです。

<?php
// ユーザーエージェント取得
$ua = $_SERVER['HTTP_USER_AGENT'];

// ユーザーエージェントによるスマホ判定
if (
    strpos($ua, 'iPhone') !== false || 
    strpos($ua, 'iPod') !== false || 
    (strpos($ua, 'Android') !== false && strpos($ua, 'Mobile') !== false)
) {
    // スマホの場合にリダイレクト
    header("Location: /sp/");
    exit();
}
?>

MobileDetectライブラリ

より精度の高いデバイス判定には、「MobileDetect」ライブラリが有効です。

MobileDetectはオープンソースのPHP用軽量ライブラリで、ユーザーエージェントやHTTPヘッダーを解析し、デバイスがスマートフォン、タブレット、またはPCかを判別します。

<?php
require_once 'Mobile_Detect.php';
$detect = new Mobile_Detect();

if ($detect->isMobile() && !$detect->isTablet()) {
    header("Location: /sp/");
    exit();
}
?>

参考サイト: