Cookie は良いものですが、一部のクライアント ブラウザは Cookie を無効にするため、Cookie に依存するプログラムが失敗したり、エラーが発生したりすることがあります。では、ユーザーが本当に Cookie を閉じた場合、PHP はどのようにセッションを再度使用する必要があるのでしょうか? 。
1. php.ini で session.use_trans_sid = 1 を設定するか、enable-trans-sid オプションをオンにして、PHP がページ間でセッション ID を自動的に渡すようにします。
2. URL を通じて値を手動で渡し、非表示のフォームを通じてセッション ID を渡します。
3. session_id をファイルやデータベースなどに保存し、クロスページプロセス中に手動で呼び出します。
アプローチ例1:
s1.php
1
2session_start();
3$_SESSION[’var1’]="ソースコード愛好家";
4$url="次のページ";
5echo $url;
6?>
s2.php
1
2session_start();
3echo "渡されたセッション変数 var1 の値は次のとおりです: ".$_SESSION[’var1’];
4?>
上記のコードを実行すると、クライアントのCookieが正常であれば「Source Code Lover」という結果が得られるはずです。
このときクライアントのCookieをオフにすると結果が得られない可能性がありますので、php.iniでsession.use_trans_sid = 1を設定するか、コンパイル時に--enable-trans-sidオプションをオンにするとよいでしょう。この時点で、「ソースコード愛好家」という結果を再取得できます
アプローチ例2:
s1.php
1
2session_start();
3$_SESSION[’var1’]="ソースコード愛好家";
4$sn = session_id();
5$url="次のページ";
6echo $url;
7?>
s2.php
1
2session_id($_GET[’s’]);
3session_start();
4echo "渡されたセッション変数 var1 の値は次のとおりです: ".$_SESSION[’var1’];
5?>
フォームを非表示にする基本原則は上記と同じです。
パス3の例:login.html
mylogin1.php
01
02$name=$_POST['name'];
03$pass=$_POST['pass'];
04if(!$name || !$pass) {
05echo "ユーザー名またはパスワードが空です。もう一度ログインしてください。";
06die();
07}
08if (!($name=="youngong" && $pass=="123") {
09echo "ユーザー名またはパスワードが間違っています。もう一度ログインしてください。";
10die();
11}
12//登録ユーザー
13ob_start();
14session_start();
15$_SESSION['user']= $name;
16$psid=session_id();
17$fp=fopen("e:tmpphpsid.txt","w+";
18fwrite($fp,$psid);
19fclose($fp);
20//本人確認が成功しました。関連する操作を実行します
21echo「ログインしました
」「;
」22echo "次のページ";
23?>
mylogin2.php
01
02$fp=fopen("e:tmpphpsid.txt","r";
03$sid=fread($fp,1024);
04fclose($fp);
05session_id($sid);
06session_start();
07if(isset($_SESSION[’user’]) && $_SESSION[’user’]="老公" {
08echo "ログインしました!";
09}
10else {
11//関連する操作を実行するために正常にログインしました
12echo "ログインしていません、アクセス権がありません";
13echo "閲覧するにはログインしてください";
14die();
15}
16?>
Cookie をオフにしてもう一度お試しください。ユーザー名: youngong パスワード: 123 ファイルを通じてセッション ID を保存します。e:tmpphpsid.txt です。データベースの利用方法については例を挙げませんが、ファイルの操作方法と同様です。上記のメソッドには共通点が 1 つあります。それは、前のページでセッション ID を取得し、それを次のページに渡す方法を見つけて、次のページの session_start() の前にコード session_id (渡されたセッション ID) を追加することです。ページ; 何かの参考になれば幸いです。
。