PHP での永続性の実装
「永続性」の概念は、作者が初めて Java に接したもので、この機能を通じて、アプリケーション オブジェクトを一連のバイト ストリームに変換し (これをオブジェクトのシリアル化と呼びます)、ネットワークに適応させることができます。送信または保存。最も驚くべきことは、シリアル化されたオブジェクトも再組み立てして以前の外観に復元できることです。これは、オペレーティング システム間の差異を自動的に補正するメカニズムを意味します。つまり、Windows マシンでシリアル化されたオブジェクトをネットワーク経由で Linux マシンに転送し、エラーなく再アセンブルできます。 「永続化」では、アプリケーション オブジェクトをアプリケーションの実行時間によって制限されないようにすることができます。オブジェクトをシリアル化してからディスクに保存し、必要なときに再度アセンブルすることで、「永続的」効果を実現できます。
興味深いのは、PHP もこの機能をサポートしており、この機能は PHP3 以降、Serialize() と Unserialize() の 2 つの関数を通じて実装されているということです。実際、ASP などの開発環境もこの機能を暗黙的にサポートしています。アプリケーション オブジェクトをセッション オブジェクトまたはアプリケーション オブジェクトに保存することは永続性の現れですが、残念ながら ASP はこのインターフェイスを明示的に提供しません。
PHP では、ほぼすべての型の変数 (これには、整数、ブール、浮動小数点、配列、オブジェクトが含まれます) をシリアル化できます。 「ほぼ」と言ったのは、リソース タイプだけがシリアル化をサポートしていないためです。これは完全に、PHP のリソース タイプが実際にはポインタであるためです。 String型に関してはバイトストリームそのものなのでシリアル化の必要は全くありません。
以下では、2 つの関数 Serialize() と Unserialize() の使用法を紹介します:
string Serialize (mixed value): 値がシリアル化された後にバイト ストリームを返します。
mixed unserialize (string str): アセンブリ オブジェクトの後に str を返します。
以下は、これら 2 つの関数の適用例です。
//class.inc.php ファイル、クラス情報の保存に使用されます
//テスト用のユーザー情報クラス
class Userinfo
{
var $username ; $パスワード;
|
関数 ユーザー情報($ユーザー名、$パスワード、$データタイム)
$this -> ユーザー名 = $ユーザー名;
$this -> パスワード = $パスワード; $this -> datetime = $datetime;
function Output()
{
echo "ユーザー情報 ->
";
echo "ユーザー名: ".$this -> ユーザー名."
"; ".$this -> username."
";
echo "Datetime: ".$this -> username."
";
}
}
?>
//login.php ファイル、以前は新しいユーザーを登録します
//クラスファイルをインポートします
require_once("class.inc.php");
//新しいオブジェクト
$user = new Userinfo($_POST[ユーザー名], $_POST[パスワード], date( "Y-n-j H :i:s"));
//オブジェクトをシリアル化する$user = Serialize($user);
//オブジェクトをローカルデータベースに書き込む
$con = mysql_connect();
mysql_select_db("test" );
mysql_query($con, "INSERT INTO testTable (id, userinfo) VALUES (1, $user)");
mysql_close($con);>
//userinfo.php ファイルを使用します。ユーザー情報
require_once("class.inc.php");
//データベースからオブジェクトを取得する
$con = mysql_connect();
$result = mysql_query($con, " SELECT) * FROM testTable WHERE id=1");
$record = mysql_fetch_assoc($result);
$user = Unserialize($record[userinfo]); //ユーザー情報を出力
$user ->output();
mysql_free ($result);
mysql_close($con);
?>
オブジェクトのシリアル化で最も重要なことは、オブジェクトのクラスの定義情報が「アセンブリ」ページに含まれていることです。そうでないとエラーが発生します。もちろん、上記はテスト用です。実際のアプリケーションでは、シリアル化されたオブジェクトの内容が変更されるのを防ぐために、通常はバイト ストリームに「デジタル署名」し、その後アセンブリ中に「デジタル署名」する必要があります。オブジェクト情報が不正に改ざんされることを防ぐための検証。
http://www.bkjia.com/PHPjc/531996.html
www.bkjia.com
本当
http://www.bkjia.com/PHPjc/531996.html
技術記事 PHP での永続性の実装 「永続性」という概念は、作者が Java に初めて触れたもので、この機能を通じて、アプリケーション オブジェクトを一連のバイト ストリーム (これを... と呼びます) に変換できます。