Zend_Serializer-Introduction.xml 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.serializer.introduction">
  5. <title>導入</title>
  6. <para>
  7. <classname>Zend_Serializer</classname> はさまざまな機関による保存可能な
  8. <acronym>PHP</acronym> 型表現の簡潔な生成と回復のインターフェイスに基づく
  9. アダプターを提供します。
  10. </para>
  11. <example id="zend.serializer.introduction.example.dynamic">
  12. <title>Zend_Serializer の動的なインターフェイスの使用</title>
  13. <para>
  14. シリアライザーをインスタンス化するにはアダプター名に基づいたファクトリーメソッド
  15. を使用しなければなりません:
  16. </para>
  17. <programlisting language="php"><![CDATA[
  18. $serializer = Zend_Serializer::factory('PhpSerialize');
  19. // この時 $serializer は Zend_Serializer_Adapter_AdapterInterface のインスタンスです,
  20. // すなわち Zend_Serializer_Adapter_PhpSerialize です
  21. try {
  22. $serialized = $serializer->serialize($data);
  23. // この時 $serialized は文字列です
  24. $unserialized = $serializer->unserialize($serialized);
  25. // now $data == $unserialized
  26. } catch (Zend_Serializer_Exception $e) {
  27. echo $e;
  28. }
  29. ]]></programlisting>
  30. </example>
  31. <para>
  32. <methodname>serialize()</methodname> メソッドは 保存できる文字列を生成します。
  33. 再生成するにはシリアライズされたデータ <methodname>unserialize()</methodname>メソッドを簡単にコールできます。
  34. </para>
  35. <para>
  36. シリアル化またはアンシリアライズにてエラーに遭遇した際は常に
  37. <classname>Zend_Serializer</classname> は
  38. <classname>Zend_Serializer_Exception</classname> をスローします。
  39. </para>
  40. <para>
  41. 特定されたシリアライザーアダプターの設定をするために、配列か <classname>Zend_Config</classname>
  42. を <methodname>factory</methodname> か <methodname>serialize()</methodname>
  43. と <methodname>unserialize()</methodname> メソッドに任意に追加できます:
  44. </para>
  45. <programlisting language="php"><![CDATA[
  46. $serializer = Zend_Serializer::factory('Wddx', array(
  47. 'comment' => 'serialized by Zend_Serializer',
  48. ));
  49. try {
  50. $serialized = $serializer->serialize(
  51. $data,
  52. array('comment' => 'change comment')
  53. );
  54. $unserialized = $serializer->unserialize(
  55. $serialized,
  56. array(/* options for unserialize */)
  57. );
  58. } catch (Zend_Serializer_Exception $e) {
  59. echo $e;
  60. }
  61. ]]></programlisting>
  62. <para>
  63. <methodname>factory()</methodname>に与えらえたオプションはインスタンス化されたオブジェクトにとって妥当なものです。
  64. <methodname>setOption(s)</methodname>メソッドを用いてこれらのオプションを
  65. 変更できます。単発の呼び出しだけをするために一つか
  66. それ以上の変更をするには、<methodname>serialize()</methodname> または
  67. <methodname>unserialize()</methodname> を第二引数として渡します。
  68. </para>
  69. <example id="zend.serializer.introduction.example.static.php">
  70. <title>Zend_Serializer の静的なインターフェイスの使用</title>
  71. <para>
  72. <classname>Zend_Serializer</classname>とともに使用するのに特別なシリアライザーを標準のシリアル化
  73. アダプターとして登録できます。デフォルトでは <classname>PhpSerialize</classname> アダプターが
  74. 登録されているでしょうが、静的メソッド <methodname>setDefaultAdapter()</methodname>
  75. を使用してこのオプションを変更できます。
  76. </para>
  77. <programlisting language="php"><![CDATA[
  78. Zend_Serializer::setDefaultAdapter('PhpSerialize', $options);
  79. // or
  80. $serializer = Zend_Serializer::factory('PhpSerialize', $options);
  81. Zend_Serializer::setDefaultAdapter($serializer);
  82. try {
  83. $serialized = Zend_Serializer::serialize($data, $options);
  84. $unserialized = Zend_Serializer::unserialize($serialized, $options);
  85. } catch (Zend_Serializer_Exception $e) {
  86. echo $e;
  87. }
  88. ]]></programlisting>
  89. </example>
  90. </sect1>
  91. <!--
  92. vim:se ts=4 sw=4 et:
  93. -->