设为首页 收藏本站
查看: 650|回复: 0

[经验分享] 如何在php中正确使用json-json在php中的使用

[复制链接]

尚未签到

发表于 2018-12-15 15:57:33 | 显示全部楼层 |阅读模式
  从5.2版本开始,PHP原生提供json_encode()和json_decode()函数,前者用于编码,后者用于解码。
  1、json_encode()
  该函数主要用来将数组和对象,转换为json格式。先看一个数组转换的例子:
  $arr = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5);
  echo json_encode($arr);
  上面代码的输出结果为:
  {"a":1,"b":2,"c":3,"d":4,"e":5}
  再看一个对象转换的例子:
  复制代码代码如下:
  $obj->body = 'another post';
  $obj->id = 21;
  $obj->approved = true;
  $obj->favorite_count = 1;
  $obj->status = NULL;
  echo json_encode($obj);
  以上代码的输出结果为:
  复制代码代码如下:
  {
  "body":"another post",
  "id":21,
  "approved":true,
  "favorite_count":1,
  "status":null
  }
  由于json只接受utf-8编码的字符,所以json_encode()的参数必须是utf-8编码,否则会得到空字符或者null。当中文使用GB2312编码,或者外文使用ISO-8859-1编码的时候,这一点要特别注意。
  2、索引数组和关联数组
  PHP支持两种数组,一种是只保存"值"(value)的索引数组(indexed array),另一种是保存"名值对"(name/value)的关联数组(associative array)。
  由于javascript不支持关联数组,所以json_encode()只将索引数组(indexed array)转为数组格式,而将关联数组(associative array)转为对象格式。
  比如,现在有一个索引数组:
  $arr = Array('one', 'two', 'three');
  echo json_encode($arr);
  其输出结果为:
  ["one","two","three"]
  如果将它改为关联数组:
  $arr = Array('1'=>'one', '2'=>'two', '3'=>'three');
  echo json_encode($arr);
  结果就变了:
  {"1":"one","2":"two","3":"three"}
  注意,数据格式从"[]"(数组)变成了"{}"(对象)。
  如果你需要将"索引数组"强制转化成"对象",可以这样写
  json_encode( (object)$arr );
  或者:
  json_encode ( $arr, JSON_FORCE_OBJECT );
  3、类(class)的转换
  下面是一个PHP的类:
  复制代码代码如下:
  class Foo {
  const ERROR_CODE = '404';
  public $public_ex = 'this is public';
  private $private_ex = 'this is private!';
  protected $protected_ex = 'this should be protected';
  public function getErrorCode() {
  return self::ERROR_CODE;
  }
  }
  现在,对这个类的实例进行json转换:
  复制代码代码如下:
  $foo = new Foo;
  $foo_json = json_encode($foo);
  echo $foo_json;
  输出结果是:
  {"public_ex":"this is public"}
  可以看到,除了公开变量(public),其他东西(常量、私有变量、方法等等)都遗失了。
  4、json_decode()
  该函数用于将json文本转换为相应的PHP数据结构。下面是一个例子:
  复制代码代码如下:
  $json = '{"foo": 12345}';
  $obj = json_decode($json);
  print $obj->{'foo'}; // 12345
  通常情况下,json_decode()总是返回一个PHP对象,而不是数组。比如:
  $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';
  var_dump(json_decode($json));
  结果就是生成一个PHP对象:
  复制代码代码如下:
  object(stdClass)#1 (5) {
  ["a"] => int(1)
  ["b"] => int(2)
  ["c"] => int(3)
  ["d"] => int(4)
  ["e"] => int(5)
  }
  如果想要强制生成PHP关联数组,json_decode()需要加一个参数true:
  $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';
  var_dump(json_decode($json),true);
  结果就生成了一个关联数组:
  复制代码代码如下:
  array(5) {
  ["a"] => int(1)
  ["b"] => int(2)
  ["c"] => int(3)
  ["d"] => int(4)
  ["e"] => int(5)
  }
  5、json_decode()的常见错误
  下面三种json写法都是错的,你能看出错在哪里吗?
  复制代码代码如下:
  $bad_json = "{ 'bar': 'baz' }";
  $bad_json = '{ bar: "baz" }';
  $bad_json = '{ "bar": "baz", }';
  对这三个字符串执行json_decode()都将返回null,并且报错。
  第一个的错误是,json的分隔符(delimiter)只允许使用双引号,不能使用单引号。第二个的错误是,json名值对的"名"(冒号左边的部分),任何情况下都必须使用双引号。第三个的错误是,最后一个值之后不能添加逗号(trailing comma)。
  另外,json只能用来表示对象(object)和数组(array),如果对一个字符串或数值使用json_decode(),将会返回null。
  var_dump(json_decode("Hello World")); //null


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-651778-1-1.html 上篇帖子: PHP中使用CURL实现GET和POST请求的方法 下篇帖子: PHP 自定义session储存 FILE 方式类 高洛峰 细说PHP
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表