ホームページ >バックエンド開発 >PHPチュートリアル >PHPのカスタム保存方法 SESSION_PHPチュートリアル
PHP では、セッション内のデータはデフォルトでファイルの形式でディスクに保存されるため、小規模な Web サイトにはこれで十分な場合があります。重要なこと: 大規模および中規模の Web サイト、または特別なニーズがある一部の Web サイトの場合、デフォルトの保存方法では要件を満たすことができなくなりました。これらのセッション内のデータを複数のサーバー間で共有できるように、セッションの保存方法を独自に定義する必要があります。
PHPはこれを解決する関数を提供しています
bool session_set_save_handler (文字列オープン、文字列クローズ、文字列読み取り、文字列書き込み、文字列破棄、文字列 gc )
関数内の各パラメーターは関数に対応します。関数の名前はカスタマイズ可能ですが、パラメーターは使用されない場合でも固定形式です。
1. open(string save_path, string session_name) は session_start パラメータ string save_path セッション アクセス パス string session_name にセッション ID の Cookie 名を渡します。
function _session_open(string save_path, string name)
{
$db=mysql_connect("localhost","root","123456","tendao");
TRUE を返します;
}
2. close はパラメータなしの session_close です
ここでデータベースを閉じる必要がありますが、一般的な Web サイトでは通常ここで閉じません。
3. read(key) はセッションキーの値を読み取ります。キーはセッション ID に対応します。
4. write(key, date) のデータは、設定されたセッション変数に対応します。形式は次のとおりです。
メール名|s:13:"qqtxt@163.com";メンバーid|s:1:"1";
5. destroy(key) ログアウトセッション
この番組セグメントでは、対応するレコード項目が削除されます。
6. gc (expiry_time) は、期限切れのセッション レコードをクリアします。
テーブル構造「セッション」
--
TABLE `セッション` を作成します (
`session_key` char(32) NOT NULL,
`session_data` char(255) NOT NULL,
`session_expiry` int(11) unsigned NOT NULL,
主キー (`session_key`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;文字セットは状況に応じて変更します
クラスセッション{
var $expiry=3600;
var $db;
関数 __construct(){
$this->セッション();
}
関数セッション(){
session_set_save_handler( array (& $this, "_session_open"),
配列 (& $this, "_session_close"),
配列 (& $this, "_session_read"),
配列 (& $this, "_session_write"),
配列 (& $this, "_session_destroy"),
配列 (& $this, "_session_gc")
);
}
/**
* セッションハンドラーを開く
*
* @param string $save_path
* @param string $セッション名
* @return boolen
*/
function _session_open($save_path, $session_name)
{
$this->db=mysql_connect("localhost","root","123456") または die("データベース接続に失敗しました!");
mysql_select_db("tendao",$this->db);
TRUE を返します;
}
関数_session_close(){
true を返します;
}
関数_session_read($key){
$expiry=time();
$s_query=sprintf("session_key= '%s' および session_expiry > %d のセッションから session_data を選択します " , $key, $expiry );
$result=mysql_query($s_query,$this->db);
$row=mysql_fetch_assoc($result);
if($row){
return $row['session_data'];
}
それ以外
FALSE を返します;
}
function _session_write($key,$data){
$expiry_time=time()+$this->有効期限;
$s_query=sprintf("session_key= '%s' のセッションから session_data を選択", $key);
$result=mysql_query($s_query,$this->db);
if(mysql_num_rows($result)==0){
$s_query=sprintf("セッション値に挿入('%s','%s', %d)",$key,$data,$expiry_time);
$result=mysql_query($s_query,$this->db);
}
他{
$s_query=sprintf("更新セッションセット session_key='%s', session_data='%s',session_expiry=%d where session_key='%s'",$key,$data,$expiry_time,$key);
$result=mysql_query($s_query,$this->db);
}
$result を返します;
}
関数_session_destroy($key){
$s_query=sprintf("session_key= '%s' のセッションから削除", $key);
$result=mysql_query($s_query,$this->db);
$result を返します;
}
関数 _session_gc($expiry_time){
$expiry_time=time();
$s_query=sprintf("session_expiry < %d" のセッションから削除", $expiry_time);
$result=mysql_query($s_query,$this->db);
$result を返します;
}
}
$_ses_=新しいセッション();
session_start();
$_SESSION['時間']=時間()+1200;
echo strval(time()).'
'.strval($_SESSION['time']);
?>
すべての著作権はゼロスペースによって留保されます