クライアントで Cookie が無効になっているときにセッションが無効にならないようにするための PHP ソリューション_PHP チュートリアル

WBOY
リリース: 2016-07-13 10:30:33
オリジナル
790 人が閲覧しました

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

クライアントで Cookie が無効になっているときにセッションが無効にならないようにするための PHP ソリューション_PHP チュートリアル

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) を追加することです。ページ; 何かの参考になれば幸いです。

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/765434.html技術記事 Cookie は良いものですが、一部のクライアント ブラウザは Cookie を無効にするため、Cookie に依存するプログラムが失敗したり、エラーが発生したりすることがあります。そのため、ユーザーが Cookie を無効にすると、P...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート