セッションストレージに関する質問
私はしばらく PHP を学習しており、MVC のアイデアに基づいてフレームワークを作成しようとしていますが、セッションをデータベースにインポートするときにいくつかの問題が発生しました。
これは SessionDBTool のコードです。 class.php ファイル:
<?phpclass SessionDBTool { //MySQLDB类的对象 private $db; public function __construct(){ //设置处理器方法 ini_set('session.save_handler', 'user'); session_set_save_handler( array($this,'sess_open'), array($this,'sess_close'), array($this,'sess_read'), array($this,'sess_write'), array($this,'sess_destroy'), array($this,'sess_gc') ); //开启session session_start(); } public function sess_open(){ $this->db = MySQLDB::getInstance($GLOBALS['config']['database']); } public function sess_close(){ return true; } public function sess_read($sess_id){ $sql = "select sess_data from it_session where sess_id = '$sess_id'"; return (string)$this->db->fetchColumn($sql); } public function sess_write($sess_id,$sess_data){ $expire = time(); $sql = "insert into it_session values('$sess_id','$sess_data',$expire) on duplicate key update sess_data = '$sess_data',expire = $expire"; return $this->db->query($sql); } public function sess_destroy($sess_id){ $sql = "delete from it_session where sess_id = '$sess_id'"; return $this->db->query($sql); } public function sess_gc($ttl){ $last_time = time() - $ttl; $sql = "delete from it_session where expire < $last_time"; return $this->db->query($sql); }}?>
これはバックグラウンド コントローラーのクラス ファイル コード:
<?php/** * Created by PhpStorm. * User: DoubleJack * Date: 2015/5/13 * Time: 23:18 */ class BackPlatformController extends Controller { /** * 构造函数,使其自动checklogin() */ public function __construct(){ //开启session $this->initSession(); //验证是否登陆 $this->checkLogin(); } /** * 初始化session入库 */ protected function initSession(){ new SessionDBTool; } /** * 验证当前用户是否登陆 */ protected function checkLogin(){ //判断是否登录 if(CONTROLLER=="admin" && (ACTION=="login" || ACTION=="signin")) { //不需要 }else{ //需要 if(isset($_SESSION['is_login']) && $_SESSION['is_login'] == 'YES'){ //载入后台的模板 require CURR_VIEW_DIR . 'index.html'; //继续执行 }else{ $this->jump('index.php?p=back&c=Admin&a=login','请先登录',2); } } } }
しかし、ログイン ページを開くと、ログイン時に「最初にログインしてください」と表示されるはずです。 SessionDBTool が初期化されていないことが原因で、私はそれを長い間調べてきましたが、どこを変更すればよいのかわかりません。解決してください。
に返信します。ディスカッション (解決策)
@xuzuning
//オープンセッション
new SessionDBTool; //この SessionDBTool オブジェクトはローカルではありませんか?
}
???
* /
関数 (メソッド) 内で作成された変数 (オブジェクト) は、関数 (メソッド) の外ではアクセスできません。 $this->pile = new SessionDBTool; などの持続可能なアクセス キャリアに保存する必要があります
それ以外の場合は、initSession が実行されます 終了後、オブジェクトは失われます
関数 (メソッド) は関数 (メソッド) の外部からアクセスできません
-$ This-& gt; のように、持続的にアクセス可能なキャリアに保存する必要があります
それ以外の場合は、initity の実装後、オブジェクトは利用できません。「ログイン」するように求められます
/ **
ProteCTED FUNINCTION Initivity ( ) {{
new SessionDBTool;
このコードは意味がありません
?
ちなみに
/** * 初始化session入库 */ protected function initSession(){ new SessionDBTool; }
はこのように書かれています 問題ありません
ありがとうございます!

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。
