json_encode 和 serialize(一)_serialize 和json_encode-程序员宅基地

技术标签: 链式学习记录  

      今天在看书的时候(作为一个菜鸟,看书是必须滴 嘿嘿),看到了序列化,php的序列化一般使用serialize和json_encode,按照之前的学习方法,我可能就只会把这个两个函数的用法区别搞清楚下就pass继续看其他内容了,但是之前在csdn博客上看到李运华老师的博客再结合平时师傅提醒的学习方法,感觉之前的老方法不是一个合格的程序员应该做的,作为一个程序员,合格的程序员应该善于挖掘(师傅说的),而李老师说的是学习一个知识应该按照链式的方法,去学习,这样才能学到更多,因此,从今天这篇博客开始,作为一个起步的菜鸟,我觉得我应该改变学习方式,用链式的方法去挖掘每碰到的问题。

     言归正传,按照新的方法,我首先对这个知识4点进行了链式的连接,先上一下总的过程,最后写具体内容:

     serialize和json_encode->他们的区别是什么??(在进行测试的时候发现中文会有乱码,按照链式学习法,这时候编码作为一个新的知识出现了)-> 为什么会乱码?编码有什么呢?gbk和utf8区别又是什么呢?(解决了编码问题之后重新回到了序列化问题)->这个时候看到书上有句话(串行化对象的时候,php会自动调用__wakeUp魔术方法) ->好的,这个时候去了解下__sleep __wakeUp魔术方法,同时了解下其他的php魔术方法-> 之后又看到书上一句话(在url中传递串行化数据的时候需要进行urlencode  编码)->这个时候去了解urlencode编码是怎么回事,同时发现了url元字符的概念 ,继续了解url元字符是什么作用呢??-> 搞明白之后,这个时候发现php序列化已经掌握的差不多了,但是同时问自己,既然json_encode 主要用于php和其他比如js语言进行交互,那么是不是也需要了解下json??->于是我又开始对json进行了解,同时心里也有个疑问,既然php有序列化,那么js的序列化呢??-> 这个时候对js序列化进行了解、

  最后,按照链式学习法挖掘,从书上看的一个简单的php序列化知识点,引申出编码,url元字符,json,js序列化,等额外的知识,学到了更多的知识,对比之前老方法只是了解完serailize和json_encode  的区别之后就pass,对知识的理解,和学到的知识深度,广度也有鲜明的对比。因此以后碰到问题就这样去学习,这样慢慢地积累下来,10000小时积累之后我一定会从一个刚毕业的菜鸟成为大牛的!!

   接下去这个过程中的具体的代码测试和知识(记录下来,作为一个总结,以后回头看也许还能发现错误呢):

1 serialize和json_encode  区别

   (1)serialize主要用于php的序列化,存储到文件或者数据库中,json_encode 也是序列化,但是 主要用于与其他语言比如js进行交互使用,对于传输来说,json有许多优点。

   (2)在显示上,serialize序列化的字符串包含额外的内容,这是值的类型和长度的编码

   (3)在进行 json_decode解码的时候需要注意,如果是序列化的数值型数组,那么json_decode 可以还原为原来的数组(数值型数组哦),但是,如果序列化的是关联数组(或者对象),那么由于json_decode无法判断是关联数组还是对象(我们可以理解为这两个长的像无法区分),所以json_decode会默认还原解析为stdclass的对象,如果加了true才解析为关联数组

$arr=array(1,2,3,'test'=>"中文");
var_dump(json_decode(json_encode($arr)));
var_dump(json_decode(json_encode($arr),true));
   输出结果分别为

object(stdClass)#1 (4) { ["0"]=> int(1) ["1"]=> int(2) ["2"]=> int(3) ["test"]=> string(6) "中文" } 
array(4) {  [0]=>  int(1)  [1]=>  int(2)  [2]=>  int(3)  ["test"]=>  string(6) "中文"}

(4)json_encode不能序列化对象的成员方法,代码如下:

  serialize序列化之后,反序列化的数据,可以重新调用成员方法,但是json_decode不行,会报错,具体可以测试、

(5)__sleep和__wakeUp魔术方法

    当一个对象被串行化,PHP会调用__sleep方法(如果存在的话,并且进行操作,比如对变量赋值). 在反串行化一个对象后,PHP 会调用__wakeup方法. 这两个方法都不接受参数. __sleep方法必须返回一个数组,包含需要串行化的属性. PHP会抛弃其它属性的值. 如果没有__sleep方法,PHP将保存所有属性.
      在程序执行前,serialize() 函数会首先检查是否存在一个魔术方法 __sleep.如果存在,__sleep()方法会先被调用, 然后才执行串行化(序列化)操作。这个功能可以用于清理对象,并返回一个包含对象中所有变量名称的数组(必须返回。与之相反,unserialize()会检查是否存在一个__wakeup方法。如果存在,则会先调用 __wakeup方法,例如可以用于数据库的重新连接

class myClass{
    public $myContent;
    public $my;
    function __construct($a){
        $this->myContent=$a;
        $this->my="second";
    }
    function __sleep(){
        $this->myContent='这是我的密码';
        return array("myContent",'my');
    }
}
$content = new myClass("dfd");
 var_dump((serialize($content)));
输出

string(82) "O:7:"myClass":2:{s:9:"myContent";s:18:"这是我的密码";s:2:"my";s:6:"second";}" 
但是只针对serialize,亲测 json_encode无效

2在输出中文的时候碰到了编码问题,因此也去了解下了编码问题,总结如下

(1)gbk和utf8 gbk主要是用于中文,utf8则是面向国际,一个中文gbk对应两个字节,utf8三个字节,所以可以通过strlen函数进行测试,现在网站都是用utf8这样比较通用(可以用在好多语言混合的网页,我的理解),windows系统呢,在中国来说 文本是默认gbk的,火狐浏览器(根据文件编码,但是感觉默认是gnk)打开文本可以显示中文,但是php文件,一般默认无bom头utf8,所以火狐浏览器打开php文件中文会乱码,因此需要用一个header函数告诉浏览器需要用什么编码解析,或者用编辑器将php文件改成utf8格式,或者在前端页面用charset设置utf8,保持编码一致就不会乱码,而谷歌浏览器,我认为应该是默认了utf8所以用谷歌浏览器打开php文件的时候是不会乱码的,一般来说,网上的页面查看源代码都会发现在前端页面几乎都有对编码进行设置,这样可以硬性规定浏览器用什么方式解析,哦对了。php设置里面也可以进行设置,default_charset
utf8支持多国语言混合的网页,所以占用的空间也比较大
gbk支持中文占用空间小 所以看具体情况具体进行使用

(2)bom头

      类似WINDOWS自带的记事本等软件,在保存一个以UTF-8编码的文件时,会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM)。它是一串隐藏的字符,用于让记事本等编辑器识别这个文件是否以UTF-8编码。对于一般的文件,这样并不会产生什么麻烦。但对于 PHP来说,BOM是个大麻烦。
php会把bom头读出来,用fgetc进行测试的时候(需要用英文,因为这个函数一次读取的是一个字节,中文包含好几个字节,每次读都是乱码容易对bom判断影响),把txt文件保存为tf8 的时候 进行fgetc读取 前两个结果都是乱码,前三个为空(显示),第四个才开始显示文本 内容,将文本编码改成gbk或者无bom头的utf8之后,发现第一个就读取出文本内容了。因此说明,php真的会将有bom头的utf8编码文件读出来:

将test.txt 文件设置成有bom头的utf8文件:

$file=fopen('test.txt','r');
 for($i=0;$i<2;$i++){
     echo fgetc($file);
}
 
fclose($file);
谷歌浏览器输出

��
把i改成4之后才开始输出文件里面的内容

或者将文件编码设置成无bom头之后就不会输出乱码了、所以php确实会输出bom头、

3urlencode

(睡了个午觉好困,写博客还挺有意思 的,记录自己成长的历程 继续码字)当url在传输序列化数据的时候,因为特殊的字符会和url元字符混淆,所以需要使用urlencode函数进行编码,url元字符主要有+,&,/,?等,因此序列化的数据有这些的都必须编码、需要注意的是空格会转成+号。解码用urldecode

4json和js的序列化

暂时先放着 ,等有空更新






版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_23289691/article/details/54870021

智能推荐

php多进程 防止出现僵尸进程_pcntl_fork 使用防止僵尸进程-程序员宅基地

文章浏览阅读1.9k次。对于用PHP进行多进程并发编程,不可避免要遇到僵尸进程的问题。僵尸进程是指的父进程已经退出,而该进程dead之后没有进程接受,就成为僵尸进程(zombie)进程。任何进程在退出前(使用exit退出) 都会变成僵尸进程(用于保存进程的状态等信息),然后由init进程接管。如果不及时回收僵尸进程,那么它在系统中就会占用一个进程表项,如果这种僵尸进程过多,最后系统就没有可以用的进程表项,于是也无法再运行其_pcntl_fork 使用防止僵尸进程

GeSHi——通用语法高亮显示-程序员宅基地

文章浏览阅读73次。ExamplesCategoryExamplesViewsActionScript246173Ada327881Apache configuration240029AppleScript00ASM227221ASP18686..._geshi 高亮

Axure RP 9滚动条制作_axure滚动条-程序员宅基地

文章浏览阅读3.5k次。Axure RP 9滚动条制作_axure滚动条

树莓派安装git和下载安装WiringPi_wiringpi 如何下载-程序员宅基地

文章浏览阅读1.1k次。具体命令如下sudo apt-get update#如果之前没有安装过 git,执行下面的命令安装一下sudo apt-get install git-core#下载 wiringPigit clone https://github.com/WiringPi/WiringPi#编译 wiringPicd WiringPisudo ./build——————2021.03.250:33..._wiringpi 如何下载

RabbitMQ系列之RabbitMQ简介_rabbitmq社区-程序员宅基地

文章浏览阅读152次。RabbitMQ简介AMQPAMQP,即Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。类比HTTPRabbitMQ架构及概念RabbitMQ基础架构:RabbitMQ中的相关概念:Broker:接收和分发消息的应用,RabbitMQ Server就是Message_rabbitmq社区

oracle 向上递归 向下递归查询_oracle向上递归结果带上底级递归id-程序员宅基地

文章浏览阅读9.3k次。---- 向上递归select distinct orgguid,dtb_orgguid,orgname from dtba_organization a start with orgguid = '2117bc0897e543168fd9702216165c77' connect by prior dtb_orgguid = orgguid orgguid 最小级别_oracle向上递归结果带上底级递归id

随便推点

C语言实现ifconfig获取网卡接收和发送流量统计_c 统计网络报文个数-程序员宅基地

文章浏览阅读671次。C语言实现ifconfig获取网卡接收和发送流量统计_c 统计网络报文个数

ArrayList循环遍历并删除元素的常见问题_arraylist y一边遍历一边移除使用增强for循环会报错吗-程序员宅基地

文章浏览阅读2.9k次,点赞2次,收藏8次。在工作和学习中,经常碰到删除ArrayList里面的某个元素,看似一个很简单的问题,却很容易出现问题。示例:我们看见删除list中‘b’的值,这种最普通的循环写法执行后会发现第二个“b”的字符没有删掉。原因:因为在ArrayList底层用的是数组实现,所以存储的时候是一块连续的地址。当检测相同元素并删除的同时,之后的整个数组就和集体往前移动,此次循环结束后的累加器又 ++1,所有相邻的一个就会被忽略掉。解决:删除后,将指针往前移一位。迭代器删除注意:如果在迭代器中用数组本身去删除会报错。_arraylist y一边遍历一边移除使用增强for循环会报错吗

爬取Google Scholar论文列表,如何利用公开数据进行合著作者分析?_爬虫爬取谷歌学术作者文章-程序员宅基地

文章浏览阅读1.8k次。Preface之前同学读研选导师,帮忙参考了一下。我发现有些老师很年轻,但是 Google Scholar 各项数据都高得离谱(主要是 citation 和 h-index ),甚至轻松碾压一些在人口耳的小牛导。直觉上来说这种应该是数据虚高了,我猜测是因为老师之间合作比较多,一篇文章挂好几个老师的名字,而这种成果共享在 gs 上的体现就是,每个人都多了一篇文章。编程学习资料点击免费领取虽然参与论文即需署名是基本的学术规范,老师们合作并共享成果肯定是没问题的,但是这会导致老师的 gs 数据虚..._爬虫爬取谷歌学术作者文章

基于正点原子阿波罗 STM32F429 上手RT-Thread_正点原子阿波罗游戏程序-程序员宅基地

文章浏览阅读3.6k次,点赞3次,收藏5次。RT-Thread STM32F429源码:https://github.com/RT-Thread/rt-thread/rt-thread 目录目录名描述bspBoard support package,RT-Thread 板级支持包(IAR/MDK 工程在 BSP 目录下的具体的 BSP 中)componentsRT-Thread 的各个组件目录documentation一些说明文件,如代码风格说明includeRT-Thread 内核的头文件_正点原子阿波罗游戏程序

NTP服务器配置-程序员宅基地

文章浏览阅读3.0k次。一、国内的NTP服务器地址如下:a. time.buptnet.edu.cn 北京邮电大学b. slb.time.edu.cn 清华大学c. slc.time.edu.cn 北京大学d. sld.time.edu.cn 东南大学二、 Linux网络时间服务器a. 安装: sudo apt-get install ntpb. 配置文件 /etc/ntp.conf :NTP服务的主要配置文件; /usr/share/zoneinfo :这...

Linux(RadHat)基础学习—虚拟机管理-程序员宅基地

文章浏览阅读189次。1.虚拟机:虚拟机指通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统。**学习中使用的是redhat系统的虚拟机它由两部分文件构成:(1).硬盘文件(qcow2文件):记录着操作系统。所有系统信息全在硬盘。qcow2文件(2).硬件信息文件(xml文件):丢失损坏可以再次生成。xml文件。2.redhat虚拟机的安装1.下载镜像,放到合适位置(下面将镜像我放到..._disk var

推荐文章

热门文章

相关标签