質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

セッション

Sessionはクライアントがサーバに送ったすべてのリクエストのことを指します。

Q&A

解決済

3回答

1138閲覧

セッションで自動ログアウトしたい

ayuayuayu

総合スコア68

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

セッション

Sessionはクライアントがサーバに送ったすべてのリクエストのことを指します。

0グッド

0クリップ

投稿2020/12/01 03:07

編集2020/12/01 04:45
```ここに言語を入力 ログインページのセッション $_SESSION['pass'] = base64_encode(openssl_random_pseudo_bytes(32)); $pass = $_SESSION['pass']; これをメインページに飛ばしてます メインページセッションの時間 ↓  ini_set("session.gc_maxlifetime","30"); ini_set('session.gc_probability', 1); ini_set('session.gc_divisor', 1); session_start(); テストなので30秒にしています。 これで30秒経過すると下の 不正アクセスの可能性あり✖ が表示されてしまうので、それを30秒経過後、自動ログアウトしました。と表示させたいです メインページでのセッション判断 if ($_GET['pass'] != $_SESSION['pass']){ echo "不正アクセスの可能性あり✖"; ?><a href="cms.php">ログインページへ戻る<a><?php exit();

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maisumakun

2020/12/01 03:09

・セッション自体はどのように構築していますか? ・自動ログアウトの条件はどのようなものでしょうか?
ayuayuayu

2020/12/01 03:16

ありがとうございます。 ログアウトに関するセッションはまだ何もつけてません。 自動ログアウト時間はテストなのでまずは短めでお願いしたいです。
maisumakun

2020/12/01 03:42

> ログアウトに関するセッションはまだ何もつけてません。 まずは、セッションを構築するのが先の話です(何もログインしていない状態を「常時ログアウト」と強弁するなら話は別ですが)。
ayuayuayu

2020/12/01 03:53

メインページとログインページを作って メインページで一定の時間が過ぎたら自動ログアウトにしたいです。 ログインの時に使ってあるセッションコード、追加しときます
m.ts10806

2020/12/01 04:25

なにをどう検索したのでしょう。 あとPHPマニュアルのセッションの項を確認し、理解した上で組んでるのでしょうか。行き当たりばったりのツギハギでは難しいかと思います。
ayuayuayu

2020/12/01 04:46

セッション 自動ログアウト とかで色々検索したのですが、初めてなのでなかなか理解ができませんでした。。
guest

回答3

0

まず、ログアウト状態を理解する必要があります。
ご本人に降臨してもらってもよさそうですけど、代わりに。

ログアウト機能の目的と実現方法 - 徳丸浩の日記

あとは、session に前回の活動時刻を保存しておき、一定以上の時間経過があれば上記処理を実施する「とか」で良いかと。

投稿2020/12/01 04:01

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ayuayuayu

2020/12/01 04:58

ありがとうございます。理解できるようみさせていただきます。 編集してみました。
guest

0

自己解決

タイム切れになったら、ログインページに飛ばす。
これでできました。
ありがとうございました。

ini_set("session.gc_maxlifetime","10"); ini_set('session.gc_probability', 1); ini_set('session.gc_divisor', 1); 省略 else if($_GET['pass'] != $_SESSION['pass']){ $login_url = "〇.php"; header("Location: {$login_url}");   exit(); }

投稿2020/12/01 07:21

ayuayuayu

総合スコア68

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2020/12/01 07:25

phpのheaderで飛ばす場合は、ブラウザ上ではログイン状態で保持されますが大丈夫ですか?
ayuayuayu

2020/12/01 08:56

ありがとうございます。 そうなんですか?? では、なにで飛ばしたらいいんですか??
guest

0

jsでセッションidのクッキーが消えたタイミングでログアウトページに飛べばよいでしょう

投稿2020/12/01 03:10

yambejp

総合スコア114572

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ayuayuayu

2020/12/01 03:21

ありがとうございます。検索してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問