検索
ホームページphp教程php手册JSON格式化与serialize序列化 - 璐小璐

一、JSON格式化

1. JSON是什么

JSON是一种数据的存储格式,用来沟通客户端Javascript和服务端PHP的交互。我们把用PHP生成JSON后的字符串传给前台Javascript,Javascirpt就可以很容易的将其反JSON然后应用。

2. 如何使用JSON

PHP操作JSON可以使用json_encode()和json_decode()两个函数——一个编码,一个解码。json_encode()可以将数组转换成json格式的文本数据,方便存储和读取,而json_decode()可以直接将json数据转换成数组,方便调用。

<span class="xml"><span class="php"><span class="hljs-preprocessor" style="color: #f99b15;"><?php</span>
    <span class="hljs-variable" style="color: #ef6155;">$arr</span> = <span class="hljs-keyword" style="color: #815ba4;">array</span>(
        <span class="hljs-string" style="color: #48b685;">'name'</span>    =<span class="hljs-string" style="color: #48b685;">'刘璐'</span>,
        <span class="hljs-string" style="color: #48b685;">'nick'</span>    =<span class="hljs-string" style="color: #48b685;">'璐小璐'</span>,
        <span class="hljs-string" style="color: #48b685;">'age'</span>     =<span class="hljs-string" style="color: #48b685;">'26'</span>,``
        <span class="hljs-string" style="color: #48b685;">'contact'</span> =<span class="hljs-keyword" style="color: #815ba4;">array</span>(
            <span class="hljs-string" style="color: #48b685;">'phone'</span>   =<span class="hljs-string" style="color: #48b685;">'13718136109'</span>,
            <span class="hljs-string" style="color: #48b685;">'address'</span> =<span class="hljs-string" style="color: #48b685;">'Beijing ifdoo'</span>
        )
    );

    <span class="hljs-variable" style="color: #ef6155;">$str</span> = json_encode(<span class="hljs-variable" style="color: #ef6155;">$arr</span>);
    <span class="hljs-keyword" style="color: #815ba4;">echo</span> <span class="hljs-string" style="color: #48b685;">"getProfile($str)"</span>;
<span class="hljs-preprocessor" style="color: #f99b15;">?></span></span>
</span>

结果为:
{"name":"\u5218\u7490","nick":"\u7490\u5c0f\u7490","age":"26","contact":{"phone":"13718136109","address":"\u5317\u4eac \u5f97\u8c46"}}

3. JSON格式的数据与WEB前端JS完成异步交互过程

PHP使用json_encode()将数组转换成json格式的数据后,此json字符串相当于JavaScript中的对象,赋给一个变量后,就可以对这个数组进行操作了。

<script <span class="hljs-typedef"><span class="hljs-keyword" style="color: #815ba4;">type</span>="text/javascript></span>
    var arr = {<span class="hljs-string" style="color: #48b685;">"name"</span>:<span class="hljs-string" style="color: #48b685;">"\u5218\u7490"</span>,<span class="hljs-string" style="color: #48b685;">"nick"</span>:<span class="hljs-string" style="color: #48b685;">"\u7490\u5c0f\u7490"</span>,<span class="hljs-string" style="color: #48b685;">"age"</span>:<span class="hljs-string" style="color: #48b685;">"26"</span>,<span class="hljs-string" style="color: #48b685;">"contact"</span>:{<span class="hljs-string" style="color: #48b685;">"phone"</span>:<span class="hljs-string" style="color: #48b685;">"13718136109"</span>,<span class="hljs-string" style="color: #48b685;">"address"</span>:<span class="hljs-string" style="color: #48b685;">"\u5317\u4eac \u5f97\u8c46"</span>}};
    alert(arr.name);  
</script>  

4. 实例

index.html

<span class="xml"><span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">html</span>></span>
<span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">head</span>></span>
    <span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">title</span>></span>json demo<span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">title</span>></span>
    <span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">script</span> <span class="hljs-attribute" style="color: #ef6155;">type</span>=<span class="hljs-value" style="color: #48b685;">"text/javascript"</span>></span><span class="javascript" style="opacity: 0.5;">
    <span class="hljs-function" style="color: #815ba4;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #06b6ef;">getProfile</span><span class="hljs-params" style="color: #f99b15;">(str)</span> </span>{
        <span class="hljs-keyword" style="color: #815ba4;">var</span> arr = str;
        <span class="hljs-built_in" style="color: #f99b15;">document</span>.getElementById(<span class="hljs-string" style="color: #48b685;">'nick'</span>).innerHTML = arr.nick;
    }
    </span><span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">script</span>></span>
<span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">head</span>></span>
<span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">body</span>></span>
    <span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">div</span> <span class="hljs-attribute" style="color: #ef6155;">id</span>=<span class="hljs-value" style="color: #48b685;">"nick"</span>></span><span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">div</span>></span>
<span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">body</span>></span>

<span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">script</span> <span class="hljs-attribute" style="color: #ef6155;">type</span>=<span class="hljs-value" style="color: #48b685;">"text/javascript"</span> <span class="hljs-attribute" style="color: #ef6155;">src</span>=<span class="hljs-value" style="color: #48b685;">"./profile.php"</span>></span><span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">script</span>></span>
<span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">html</span>></span>
</span>

profile.php

<span class="xml"><span class="php"><span class="hljs-preprocessor" style="color: #f99b15;"><?php</span>
    <span class="hljs-variable" style="color: #ef6155;">$arr</span> = <span class="hljs-keyword" style="color: #815ba4;">array</span>(
        <span class="hljs-string" style="color: #48b685;">'name'</span>    => <span class="hljs-string" style="color: #48b685;">'刘璐'</span>,
        <span class="hljs-string" style="color: #48b685;">'nick'</span>    => <span class="hljs-string" style="color: #48b685;">'璐小璐'</span>,
        <span class="hljs-string" style="color: #48b685;">'age'</span>     => <span class="hljs-string" style="color: #48b685;">'26'</span>,
        <span class="hljs-string" style="color: #48b685;">'contact'</span> => <span class="hljs-keyword" style="color: #815ba4;">array</span>(
            <span class="hljs-string" style="color: #48b685;">'phone'</span>   => <span class="hljs-string" style="color: #48b685;">'13718136109'</span>,
            <span class="hljs-string" style="color: #48b685;">'address'</span> => <span class="hljs-string" style="color: #48b685;">'Beijing ifdoo'</span>
        )
    );

    <span class="hljs-variable" style="color: #ef6155;">$str</span> = json_encode(<span class="hljs-variable" style="color: #ef6155;">$arr</span>);
    <span class="hljs-keyword" style="color: #815ba4;">echo</span> <span class="hljs-string" style="color: #48b685;">"getProfile($str)"</span>;
<span class="hljs-preprocessor" style="color: #f99b15;">?></span></span>
</span>
  • html页面调用PHP文件

    <script language="text/javascript" src="/xx/a.php"></script>

    a.php中的echo输出的是javascript代码。

  • php页面调用js文件

    a.php中的echo js里的方法即可。

二、serialize序列化

1. serialize 是什么

serialize是将变量序列化,返回一个具有变量类型和结构的字符串表达式。

2. 如何使用serialize

使用PHP的serialize和unserialize将数组进行序列化和反序列化。

<span class="xml"><span class="php"><span class="hljs-preprocessor" style="color: #f99b15;"><?php</span>
    <span class="hljs-variable" style="color: #ef6155;">$arr</span> = <span class="hljs-keyword" style="color: #815ba4;">array</span>( 
        <span class="hljs-string" style="color: #48b685;">"u1"</span> => <span class="hljs-keyword" style="color: #815ba4;">array</span>( 
            <span class="hljs-string" style="color: #48b685;">"gameName"</span> => <span class="hljs-string" style="color: #48b685;">"德乙"</span>, 
            <span class="hljs-string" style="color: #48b685;">"homeName"</span> => <span class="hljs-string" style="color: #48b685;">"比勒费尔德"</span>, 
            <span class="hljs-string" style="color: #48b685;">"guestName"</span> => <span class="hljs-string" style="color: #48b685;">"不伦瑞克"</span>, 
            <span class="hljs-string" style="color: #48b685;">"endTime"</span> => <span class="hljs-string" style="color: #48b685;">"2015-08-21"</span> 
        ), 
        <span class="hljs-string" style="color: #48b685;">"u2"</span> => <span class="hljs-keyword" style="color: #815ba4;">array</span>( 
            <span class="hljs-string" style="color: #48b685;">"gameName"</span> => <span class="hljs-string" style="color: #48b685;">"英超"</span>, 
            <span class="hljs-string" style="color: #48b685;">"homeName"</span> => <span class="hljs-string" style="color: #48b685;">"水晶宫"</span>, 
            <span class="hljs-string" style="color: #48b685;">"guestName"</span> => <span class="hljs-string" style="color: #48b685;">"阿斯顿维拉"</span>, 
            <span class="hljs-string" style="color: #48b685;">"endTime"</span> => <span class="hljs-string" style="color: #48b685;">"2015-08-22"</span> 
        ) 
    ); 
    <span class="hljs-keyword" style="color: #815ba4;">echo</span> serialize(<span class="hljs-variable" style="color: #ef6155;">$arr</span>);
<span class="hljs-preprocessor" style="color: #f99b15;">?></span></span>
</span>

结果为:

a:2:{s:2:"u1";a:4:{s:8:"gameName";s:6:"德乙";s:8:"homeName";s:15:"比勒费尔德";s:9:"guestName";s:12:"不伦瑞克";s:7:"endTime";s:10:"2015-08-21";}s:2:"u2";a:4:{s:8:"gameName";s:6:"英超";s:8:"homeName";s:9:"水晶宫";s:9:"guestName";s:15:"阿斯顿维拉";s:7:"endTime";s:10:"2015-08-22";}}

其中:

a:2说明这是个有两个元素的数组(array);
i:0指序列索引;
a:4指有4个字段;
s:8:"gameName"说明这是有8个字符的字符串(string)

总结: PHP的serialize将数组序列化后是便于存储,而JSON格式的数据不仅便于存储还能跟其他语言如javascript读取。如果前后端交互使用比较多的话建议使用JSON,结合PHP、Javascript、JSON以及Ajax就可以完成强大的数据交互功能。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール