ホームページ >バックエンド開発 >PHPチュートリアル >PHP の一般的な問題と解決策のコレクション session_PHP チュートリアル
PHP セッションの FAQ と解決策:
1.
エラーメッセージ
警告: セッション Cookie を送信できません - ヘッダーはすでに送信されています
警告: セッション キャッシュ リミッターを送信できません - ヘッダーはすでに送信されています
分析と解決策
この種の問題が発生する理由は、プログラム内で session_start() を使用するときに、実際の HTML コンテンツが以前に出力されているためです。おそらく、私はそれを持っていないので、メッセージをエコーするか印刷するだけだと言うかもしれません。申し訳ありませんが、echo または print ステートメントによって生成される出力は、実際の HTML コンテンツ出力です。この種の問題を解決する方法は、session_start() をプログラムの最初の行に移動することです。
2.
エラーメッセージ
警告: open(F:/689phpsessiondatasess_66a39376b873f4daecf239891edc98b5, O_RDWR) が失敗しました
分析と解決策
このようなエラー ステートメントが発生するのは、通常、php.ini の session.save_path 項目が適切に設定されていないことが原因です。解決策は、session.save_path と session.cookie_path の設定を
に設定することです。session_save_path = c:temp
session.cookie_path = c:temp
そして、c:ディレクトリにtempディレクトリを作成するだけです
3.
エラーメッセージ
警告:
の初期化されていないセッションを破棄しようとしています分析と解決策
このようなプロンプトは通常、session_destroy() 関数を直接調整することによって発生します。多くの友人は、session_destroy() 関数が独立して実行できると考えていますが、そうではありません。解決策は、session_destroy() 関数を呼び出す前に session_start() を使用してセッション関数を有効にすることです。
4. 質問: 現在のセッションの ID 値を取得するにはどうすればよいですか?
最も簡単な方法は次のとおりです:
エコーSID;
わかりますよ。
5. 質問: ヘッダー関数を呼び出す前にプログラムに出力がありません。config.php ファイルをインクルードしているのに、セッションで同じエラーが報告されるのはなぜですか?ヘッダーの前に session_start() を使用したためですか?
回答: おそらく、PHP プログラムを慎重にチェックしましたが、確かに header() を参照する前に出力がなく、インクルード ファイルにも出力がありません。しかし、入力するためにカーソル キーを使用しましたか?> ;移動についてはどうでしょうか。この PHP コードの end ステートメントの後ろを確認してください。すると、?> の後に空白行または複数のスペースがあることがわかります。これらの空白行またはスペースを削除すると、問題は解決します。
注: この問題は PHP4.1.2 以降のバージョンで発生しますが、テストされていません。
6. 質問: セッションを使用してメインページにログインした後、セッションを使用して他のページでのログインを制限するにはどうすればよいですか? 。 。
答え: 最も簡単な方法は
session_start();
if(!session_registered('login') ││login != true) {
echo "あなたはログインしていません";
退出;
}
7. 質問: session_register() を使用してセッション変数を登録しましたが、ヘッダーまたは JavaScript リダイレクトステートメントを使用すると、次のページでセッションによって登録された変数値にアクセスできません。どうやって解決しますか?
問題のプログラムの断片:
session_start();
ok = 「愛しています」;
session_register('ok');
header("location : next.php");
?>
next.php
session_start();
エコーOK;
?>
解決策:
header関数やwindow.locationなどの関数を使用すると、前のページで登録したセッション変数が簡単に失われてしまう この問題の原因についてはまだ詳しい答えはありません。
しかし、解決策はあります。以下に示すように
Header("場所: next.php" ."?" . SID);
次のページにジャンプするときは、セッションの現在の ID をパラメータとして使用し、次のページに渡します。
8.セッションで配列を渡す方法
session_register('data');
データ=配列(1,2,3,4);
最初に登録してから値を割り当てる方法です
9. 質問9: HTTP_GET_VARS['**'] のようなメソッドを使用してセッション値にアクセスできますか?
回答: はい、次のグローバル配列を使用してセッションにアクセスし、Web ページのセキュリティを強化できます
HTTP_SESSION_VARS
_セッション
ルーティン:
コード:
session_start();
ユーザー名 = 'stangly.wrong';
session_register('ユーザー名');
echo HTTP_SESSION_VARS['ユーザー名'];
エコー
';
echo _SESSION['ユーザー名'];
?>
このルーチンを参照して、自分のニーズに合わせてプログラムを修正してください。
質問 10: session_unregister() と session_destroy() の違いは何ですか?
session_unregister()関数の主な機能は、現在のセッション変数の登録を解除することです。ただし、HTTP_SESSION_VARS または _SESSION を使用して現在のページのセッション変数を参照する場合は、unset() と連携してセッション変数の設定を解除する必要がある場合があることに注意してください。
そして session_destroy() は現在のセッション環境をクリアします。これは、session_destroy() 関数を使用した後は、session_is_registered() を使用してセッション変数を検出できなくなることを意味します。ただし、グローバル内のセッションをクリアしたり、セッション Cookie を使用したりすることはできないので、 session_destroy を使用する前に、セッションにアクセスするために HTTP_SESSION_VARS _SESSION を使用しないことをお勧めします。
ルーティン:if(isset(_COOKIE[セッション名()])) {
session_start();
session_destroy();
unset(_COOKIE[session_name()]);
}