ホームページ >バックエンド開発 >PHPチュートリアル >phpのserialize()とunserialize()の違い
この記事では主にphpのserialize()とunserialize()の違いを紹介します。必要な方は参照してください
serialize()とunserialize()についてはphpマニュアルで説明されています:
serialize — の保存可能な表現を生成します。 value
serialize
— 保存された表現から PHP 値を作成しますserialize
— 产生一个可存储的值的表示
unserialize — Creates a PHP value from a stored representation
unserialize
unserialize
— 保存された表現から の PHP 値 明らかに、「保存された表現」の説明は、保存可能な値に変換された後でも非常にわかりにくいです。 言語を明確に表現できない場合は、特定の PHP の例を使用して、これら 2 つの関数の使い方を学ぶことができます
<?php //声明一个类 class dog { var $name; var $age; var $owner; function dog($in_name="unnamed",$in_age="0",$in_owner="unknown") { $this->name = $in_name; $this->age = $in_age; $this->owner = $in_owner; } function getage() { return ($this->age * 365); } function getowner() { return ($this->owner); } function getname() { return ($this->name); } } //实例化这个类 $ourfirstdog = new dog("Rover",12,"Lisa and Graham"); //用serialize函数将这个实例转化为一个序列化的字符串 $dogdisc = serialize($ourfirstdog); print $dogdisc; //$ourfirstdog 已经序列化为字符串 O:3:"dog":3:{s:4:"name";s:5:"Rover";s:3:"age";i:12;s:5:"owner";s:15:"Lisa and Graham";} print '<BR>'; /* ----------------------------------------------------------------------- 在这里你可以将字符串 $dogdisc 存储到任何地方如 session,cookie,数据库,php文件 ----------------------------------------------------------------------- */ //我们在此注销这个类 unset($ourfirstdog); /* 还原操作 */ /* ----------------------------------------------------------------------- 在这里将字符串 $dogdisc 从你存储的地方读出来如 session,cookie,数据库,php文件 ----------------------------------------------------------------------- */ //我们在这里用 unserialize() 还原已经序列化的对象 $pet = unserialize($dogdisc); //此时的 $pet 已经是前面的 $ourfirstdog 对象了 //获得年龄和名字属性 $old = $pet->getage(); $name = $pet->getname(); //这个类此时无需实例化可以继续使用,而且属性和值都是保持在序列化之前的状态 print "Our first dog is called $name and is $old days old<br>"; print '<BR>'; ?>また、例内のオブジェクトを配列などの他の型に変更することもできます。同じ効果ですよ! 実際、serialize()は、オブジェクトや配列などのPHPの変数の値を文字列にシリアル化し、シリアル化された文字列をデータベースやセッション、Cookie、などの他の場所に保存することができます。など、シリアル化操作によってこれらの値の型と構造が失われることはありません。このようにして、これらの変数のデータは、PHP ページ間、さらには異なる PHP プログラム間で受け渡すことができます。 そして unserialize() はシリアル化された文字列を PHP 値に変換します。 これも PHP マニュアルからの引用です。上記の例を読むと、次の単語の意味が簡単に理解できるはずです シリアル化された文字列を PHP 値に戻したい場合は、 unserialize( を使用できます。 )。 Serialize() はリソース以外のあらゆる型を処理できます。それ自体への参照を含む配列を Serialize() することもできます。 Serialize() している配列/オブジェクト内の参照も保存されます。 オブジェクトをシリアル化するとき、PHP はシーケンスアクションの前にオブジェクトのメンバー関数 __sleep() を呼び出そうとします。これにより、オブジェクトがシリアル化される前にクリーンアップ操作を実行できるようになります。同様に、unserialize() を使用してオブジェクトを復元する場合、__wakeup() メンバー関数が呼び出され、単一のシリアル化された変数を処理し、それを PHP 値に変換します。返されるのは変換された値で、整数、浮動小数点、文字列、配列、またはオブジェクトのいずれかになります。渡された文字列が逆シリアル化できない場合は FALSE を返します。 関連する推奨事項:
phpのserialize()およびunserialize()関数の例の詳細な説明
フォームフォーマットプラグインjquery.serializeJSONの詳細な説明
Ajaxのserialize()フォームをシリアル化してアップロードするファイル
🎜
以上がphpのserialize()とunserialize()の違いの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。