ホームページ >バックエンド開発 >PHPチュートリアル >discuz がセッションをクリアすると、セッション保存メカニズムが失敗し、セッションを更新および解決できなくなります_PHP チュートリアル
[php]
関数 userErrorHandler() {
$e = func_get_args();
echo '
<br/>----------実行エラー---------:<br/>' .print_r($e, 1).'<br/>----------実行エラー-----------<br/>';
<br/>++++++低レベルエラー+++++<br/> '.print_r($a, 1).'<br/>++++++低レベルのエラー++++<br/>'; }
<br/>----------実行エラー---------:<br/>' .print_r($e, 1).'<br/>----------実行エラー-----------<br/>';
<br/>++++++低レベルエラー+++++<br/> '.print_r($a, 1).'<br/>++++++低レベルのエラー++++<br/>'; }
switch($_GET['how']) {
ケースの「://set
」
session_start();
$_SESSION['qidizi'] = ランド();
echo $_SESSION['qidizi'];
休憩;
case 'u'://unset
session_start();
$_SESSION['qidizi'] = 'qidiziUNSET';
echo $_SESSION['qidizi'];
休憩
case 'g'://get
session_start();
var_dump($_SESSION);
休憩;
case 'c'://clean
session_start();
echo 'get--------
';
var_dump($_SESSION);
echo '
編集------';
$_SESSION['qidizi'] = 'qidiziCLEAN';
var_dump($_SESSION);
echo '
クリーン中----------
';
$GLOBALS['_SESSION']=null;unset($GLOBALS['_SESSION']);//設定解除後、セッションは無効になります
empty($GLOBALS['_SESSION']) && ($GLOBALS['_SESSION']['qidiziReBuid'] = '1');//この文ではセッション保存メカニズムを再構築/再トリガーできません
Session_write_close();//セッションの変更を事前に保存します。Discuz はセッションをクリアし、保存メカニズムを失敗させます。qidizi により、この文は有効です。
var_dump($_SESSION);
休憩;
}
上記はテストコードです
鍵は $GLOBALS['_SESSION']=null; という文にあります。
[php]
unset($GLOBALS['_SESSION']); は、セッションの解析後にセッションの保存に失敗します。デモでは、セッションの自動保存メカニズムが何であるかがわかりません。コードが保存メカニズムをトリガーしません。
discuz_application クラスでは、グローバル変数がクリアされます。
だから
正の面の変数を保持する必要はありません
var $スーパーグローバル = 配列(
'_GET' => 1,
'_POST' => 1,
'_REQUEST' => 1,
'_COOKIE' => 1,
'_SERVER' => 1,
'_ENV' => 1,
'_FILES' => 1,
);
その後、フロントコードでクリアされます
foreach ($GLOBALS as $key => $value) {
If (!isset($this->スーパーグローバル[$key])) {
$GLOBALS[$key] = null;
}
}
最終的な効果は次のコード関数として表示されます
キーは $GLOBALS['_SESSION']=null; です。
上記のテストコードをデモンストレーションに使用します:
肯定的なステートメントは、local.q/t.php?how=s(setting)|g(get)|u(modify)|c(clear) を参照します
操作ステップ 1 設定 -> 取得 -> 変更 -> 結果の取得、変更は取得中に結果にフィードバックされます
操作手順 2 Set->Get->Modify->Clear->Get ==== 結果: クリアされたデータの取得は正常に完了しました。 (ここでのテストはテストを進めるものではないことに注意してください)
それを防ぐために他の方法を使用することもできますが、このセッションの通常のメカニズムは破壊されます。
これを書いている現在、そのメカニズムを復元するためにどのような方法を使用できるかは不明です。
テストの結果、セッションを事前に保存するには session_write_close(); を使用するのが合理的であることがわかりました。これにより、セッションをクリアした後に自動保存が必要になるという問題が解決されました。