php 中序列化和json使用介紹_PHP教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦:php采集文章中的圖片獲取替換到本地
      本篇文章是對php采集文章中的圖片獲取替換到本地的實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下 復(fù)制代碼 代碼如下: /** * 獲取替換文章中的圖片路徑 * @param string $xstr 內(nèi)容 * @param string $keyword 創(chuàng)建照片的文件名 * @param string $oriweb 網(wǎng)址 * @retur

      【序列化的概念】

      序列化是將對象狀態(tài)轉(zhuǎn)換為可保持或可傳輸?shù)母袷降倪^程。與序列化相對的是反序列化,它將流轉(zhuǎn)換為對象。這兩個(gè)過程結(jié)合起來,可以輕松地存儲(chǔ)和傳輸數(shù)據(jù)。

      將對象的狀態(tài)信息轉(zhuǎn)換為可以存儲(chǔ)或傳輸?shù)拇绑w的過程。 在序列化期間,對象將其當(dāng)前狀態(tài)寫入到臨時(shí)或持久性存儲(chǔ)區(qū)。以后,可以通過從存儲(chǔ)區(qū)中讀取或反序列化對象的狀態(tài),重新創(chuàng)建該對象。

      通常,對象實(shí)例的所有字段都會(huì)被序列化,這意味著數(shù)據(jù)會(huì)被表示為實(shí)例的序列化數(shù)據(jù)。這樣,能夠解釋該格式的代碼有可能能夠確定這些數(shù)據(jù)的值,而不依 賴于該成員的可訪問性。類似地,反序列化從序列化的表示形式中提取數(shù)據(jù),并直接設(shè)置對象狀態(tài),這也與可訪問性規(guī)則無關(guān)。 對于任何可能包含重要的安全性數(shù)據(jù)的對象,如果可能,應(yīng)該使該對象不可序列化。如果它必須為可序列化的,請嘗試生成特定字段來保存不可序列化的重要數(shù)據(jù)。 如果無法實(shí)現(xiàn)這一點(diǎn),則應(yīng)注意該數(shù)據(jù)會(huì)被公開給任何擁有序列化權(quán)限的代碼,并確保不讓任何惡意代碼獲得該權(quán)限。

      【JSON的概念】

      JSON,JavaScript Object Notation,一種更輕、更友好的用于接口(AJAX、REST等)數(shù)據(jù)交換的格式。 JSON是結(jié)構(gòu)化數(shù)據(jù)串行化的文本格式,作為XML的一種替代品,用于表示客戶端與服務(wù)器間數(shù)據(jù)交換有效負(fù)載的格式。它是從ECMAScript語言標(biāo)準(zhǔn) 衍生而來的。JSON的設(shè)計(jì)目標(biāo)是使它成為小的、輕便的、文本的,而且是JavaScript的一個(gè)子集。

      【長度的比較】

      如下一段代碼,顯示了對數(shù)組和對象編碼后生成的字符串及其長度

      復(fù)制代碼 代碼如下:
      class Foo {

          public $int = 1;
          public $bool = TRUE;
          public $array = array(array(1), 2 => 'test', 'string');

          public function test($flag) {
              echo $flag, 'test function for Foo <br />';
          }

          public static function output($str) {
              echo $str, '<br />';
          }

          public static function compare_serialize_and_json($data) {
              $serialize_str =  serialize($data);
              self::output('序列化后的值:' . $serialize_str . "; length=" .
                  strlen($serialize_str));

              $json_str = json_encode($data);
              self::output('JSON后的值:' . $json_str . "; length=" . strlen($json_str));
          }

      }

      $test_data = array('wwww' => 0, 'phppan' => 1, 'com' => 2);
      //序列化數(shù)組

      echo '數(shù)組:<br />';
      Foo::compare_serialize_and_json($test_data);

      $foo = new Foo();
      echo '對象:<br />';
      Foo::compare_serialize_and_json($foo);

      輸出:

      復(fù)制代碼 代碼如下:
      數(shù)組:
      序列化后的值:a:3:{s:4:"wwww";i:0;s:6:"phppan";i:1;s:3:"com";i:2;}; length=52
      JSON后的值:{"wwww":0,"phppan":1,"com":2}; length=29
      對象:
      序列化后的值:O:3:"Foo":3:{s:3:"int";i:1;s:4:"bool";b:1;s:5:"array";a:3:{i:0;
          a:1:{i:0;i:1;}i:2;s:4:"test";i:3;s:6:"string";}}; length=111
      JSON后的值:{"int":1,"bool":true,"array":{"0":[1],"2":"test","3":"string"}}; length=63

      很明顯的長度區(qū)別,serialize在編碼后大概是json的兩倍。

      原因:

      •serialize后字符串包含了子串的長度,這可能是速度方面的優(yōu)化,典型的空間換時(shí)間,但是它本身還是太重了。
      •serialize有更加詳細(xì)的類型區(qū)分,而json只有四種類型,并且是以簡單的符號表示。

      【速度的比較】

      以代碼說明問題,如下比較速度的代碼:

      復(fù)制代碼 代碼如下:
      $max_index = 10;
      ini_set("memory_limit","512M");
      $array = array_fill(0, 1000000, rand(1, 9999));

      echo 'serialize:<br />';
      $start = xdebug_time_index();
      for ($i = 0;  $i < $max_index; $i++) {
          $str = serialize($array);
      }
      $end = xdebug_time_index();
      echo $end - $start, '<br />';

      echo 'json:<br />';
      $start = xdebug_time_index();
      for ($i = 0;  $i < $max_index; $i++) {
          $str = json_encode($array);
      }
      $end = xdebug_time_index();
      echo $end - $start, '<br />';
      unset($array, $str);

      輸出:

      復(fù)制代碼 代碼如下:
      serialize:
      9.5371007919312
      json:
      1.4313209056854

      serialize的速度在大數(shù)據(jù)量的情況下比json差了快一個(gè)數(shù)量級。

      從上面兩點(diǎn)看,json不管是在速度還是在生成的字符串的大小上都比serialize要好,那為什么serialize還要存在呢? 原因在下面這個(gè)點(diǎn):實(shí)現(xiàn)的功能。

      【處理對象】

      如下代碼:

      復(fù)制代碼 代碼如下:
      header("Content-type:text/html;charset=utf8");
      class Foo {
           public function test($flag) {
              echo $flag, 'test function for Foo <br />';
          }
      }

      $foo = new Foo();

      echo '反序列化測試:<br />';
      $foo->test(1);
      $serialize_str = serialize($foo);
      $obj = unserialize($serialize_str);
      $obj->test(2);

      $foo->test(1);
      $json_str = json_encode($foo);
      $obj = json_decode($json_str);
      $obj->test(2);
      die();

      輸出:

      復(fù)制代碼 代碼如下:
      反序列化測試:
      1test function for Foo
      2test function for Foo
      1test function for Foo

      ( ! ) Fatal error: Call to undefined method stdClass::test()

      json無法處理對象方法等數(shù)據(jù)。

      【使用范圍】

      分享:解析將多維數(shù)組轉(zhuǎn)換為支持curl提交的一維數(shù)組格式
      本篇文章是對將多維數(shù)組轉(zhuǎn)換為支持curl提交的一維數(shù)組格式實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下 復(fù)制代碼 代碼如下: /** * @desc 多維數(shù)組轉(zhuǎn)化為支持curl提交數(shù)組 * @author腳本之家 2013-07-8 */ public function toPost(array $params = array(), $pre = '

      共2頁上一頁12下一頁
      來源:模板無憂//所屬分類:PHP教程/更新時(shí)間:2013-07-09
      相關(guān)PHP教程