投稿日:2017/04/24
更新日:2017/06/19
特定のページのみ、パスワード入力後の閲覧をしたいときの設定。
このサイトのスタッフ専用ページや上野動物公園のおすすめ飲食店ページなど設定されています。
こちらを参考に上記の設定を行いました。
_setting.php
basic認証の機能を記述する。
//Basic認証
function basic_auth($auth_list,$realm="Restricted Area",$failed_text="認証に失敗しました"){
if (isset($_SERVER['PHP_AUTH_USER']) and isset($auth_list[$_SERVER['PHP_AUTH_USER']])){
if ($auth_list[$_SERVER['PHP_AUTH_USER']] == $_SERVER['PHP_AUTH_PW']){
return $_SERVER['PHP_AUTH_USER'];
}
}
header('WWW-Authenticate: Basic realm="'.$realm.'"');
header('HTTP/1.0 401 Unauthorized');
header('Content-type: text/html; charset='.mb_internal_encoding());
die($failed_text);
}
header.php
どのページにbasic認証の機能を効かせたいか記述します。
<?php
//Basic認証
if(is_page('21')) {
$userArray = array(
"ユーザー名" => "パスワード"
);
basic_auth($userArray);
}
?>
上記は
固定ページid=’21’のページのとき
basic認証を効かせる場合の記述になります。