json_encode 和 serialize(一)

      今天在看书的时候(作为一个菜鸟,看书是必须滴 嘿嘿),看到了序列化,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的序列化

暂时先放着 ,等有空更新






  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值