목차
一、JSON格式化
二、serialize序列化
php教程 php手册 JSON格式化与serialize序列化 - 璐小璐

JSON格式化与serialize序列化 - 璐小璐

May 20, 2016 am 10:14 AM

一、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 Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)