この記事は最後に更新してから1年以上経過しています。

一定時間でログアウトする

説明

ログイン関係を調べている関係で、 wp_set_auth_cookie関数に行き着く。ログイン画面の「ログイン状態を保持する」がチェックされた場合、クッキーの有効期限は14日間。チェックされていない場合は、ブラウザが閉じるまで常に有効となっているんだね。

というわけで本題へ。Webアプリケーションの中にはログインして一定時間何もしなかった場合にログアウトするものがある。今回やりたいことはまさにこれである。

ロジックは至極シンプルで、管理者ページが表示される際に実行されるadmin_initアクションにて、ログイン情報を含んだクッキーの有効期限を設定し続けるだけである。これであれば管理者ページが表示される度に有効期限は延長されるため、最終表示から所定の時間が経過した場合のみログアウトになる。

テーマのfunctions.phpに記述する内容は次の通り。すでにadmin_initアクションを使っている場合は適宜修正して使ってください。

add_action( 'admin_init', 'mytheme_admin_init' );
function mytheme_admin_init() {
	add_filter( 'auth_cookie_expiration', 'mytheme_auth_cookie_expiration', 10, 3 );
	$user = wp_get_current_user();
	wp_set_auth_cookie( $user->ID, true );
}
function mytheme_auth_cookie_expiration( $expiration, $user_id, $remember ) {
	if ( $remember ) $expiration = <span class="blue">3600</span>;
	return $expiration;
}

この例では、管理者ページを表示した際、前回のアクセスから1時間(3,600秒)経過しているとログアウトしてログインページを表示することになる。ログイン維持時間(クッキー有効期限)を変更する場合、青字の部分の秒指定を変更すること。

最近ブラウザを閉じることはあまりなくなってきており、より安全なサイト運用を心がけるなら、多少の利便性を犠牲にしてもログイン維持時間は設定しておくといいだろう。


最終更新 : 2013年05月23日 15:32


お勧め

home_url(2023年3月31日 更新)

string home_url( [ string $path = '' [ , string $scheme = null ] ] )
現在のブログ(サイト)のホームURLを取得する。ホームURLは、管理者ページの「設定」-「一般」の「サイトのアドレス(URL)」のこと。

get_comment_meta(2014年3月9日 更新)

mixed get_comment_meta( int $comment_id [ , string $key = '' [ , bool $single = false ] ] )
コメントメタ情報の値を取得する。

wp_maybe_inline_styles(2025年12月4日 更新)

void wp_maybe_inline_styles()
CSSファイルの追加情報をインライン化する。

next_posts_link(2018年5月27日 更新)

void next_posts_link( [ string $label = 'Next Page &raquo;' [ , int $max_page = 0 ] ] )
カテゴリーやタグなどのアーカイブページにおいて、1ページの投稿件数以上の投稿があった場合に次ページへのリンクを表示する。

wp_lazy_loading_enabled(2023年8月11日 更新)

bool wp_lazy_loading_enabled( string $tag_name, string $context )
要素にloading属性を追加するか判定する。