Linux PHP增加JSON支持及如何使用JSON

目前,JSON已经成为最流行的数据交换格式之一,各大网站的API几乎都支持它。

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写,同时也易于机器解析和生成。语法和XML有相似支持,使JSON成为理想的数据交换语言。

一、增加JSON支持:

PHP5.2以后的版本默认支持JSON。但Centos 5.X自带的是PHP5.1.6 故需要手工安装

但在yum升级包里找不到JSON,安装步骤如下:

# yum install php-devel  # yum install php-pear
# pear install pecl/json

downloading json-1.2.1.tgz ...
Starting to download json-1.2.1.tgz (17,780 bytes)
......done: 17,780 bytes

.................................................

uild process completed successfully
Installing '/var/tmp/pear-build-root/install-json-1.2.1//usr/lib/php/modules/json.so'
install ok: channel://pear.php.net/json-1.2.1
# cd /etc/php.d
# echo "extension=json.so" > json.ini
# service httpd restart

之后使用phpinfo()输出到网页,查找关键字"json"
json support enabled
json version 1.2.1

另外在PHP5.2中,可能需要打开/usr/local/php5/etc/extensions.ini文件中的“ extension=json.so”这一行。

二、PHP中如何使用JSON:

从5.2版本开始,PHP原生提供json_encode()和json_decode()函数,前者用于编码,后者用于解码。

1、json_encode()

该 函数主要用来将数组和对象,转换为json格式。先看一个数组转换的例子:结果为再看一个对象转换的例子:结果为由于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)转为对象格式。

比如,现在有一个索引数组结果为:如果将它改为关联数组:结果就变了:注意,数据格式从"[]"(数组)变成了"{}"(对象)。

如果你需要将"索引数组"强制转化成"对象",可以这样写或者

3、类(class)的转换

下面是一个PHP的类:现在,对这个类的实例进行json转换:输出结果是可以看到,除了公开变量(public),其他东西(常量、私有变量、方法等等)都遗失了。

4、json_decode()

该 函数用于将json文本转换为相应的PHP数据结构。下面是一个例子:通常情况下,json_decode()总是返回一个PHP对象,而不是数组。比 如:结果就是生成一个PHP对象:如果想要强制生成PHP关联数组,json_decode()需要加一个参数true:结果就生成了一个关联数组:5、 json_decode()的常见错误

下面三种json写法都是错的,你能看出错在哪里吗?对这三个字符串执行json_decode()都将返回null,并且报错。

第一个的错误是,json的分隔符(delimiter)只允许使用双引号,不能使用单引号。第二个的错误是,json名值对的"名"(冒号左边的部分),任何情况下都必须使用双引号。第三个的错误是,最后一个值之后不能添加逗号(trailing comma)。
 
另外,json只能用来表示对象(object)和数组(array),如果对一个字符串或数值使用json_decode(),将会返回null。

  var_dump(json_decode("Hello World")); //null

6、参考材料

  * PHP Manual

  * Ed Finkler, JSON is Everybody's Friend

转载于:https://www.cnblogs.com/u0mo5/p/4514297.html

Linux PHP增加JSON支持及如何使用JSON相关推荐

  1. mysql操作json优点和缺点_MYSQL 5.7中的本机JSON支持:MYSQL中JSON数据类型的优缺点是什么?...

    在MySQL 5.7中,新的数据类型用于在JSON表中存储JSON数据. 添加. 显然,这将是MySQL的巨大变化. 他们列出了一些好处 Document Validation - Only vali ...

  2. Qt中的JSON支持

    Qt中的JSON支持 Qt中的JSON支持 概述 JSON类 Qt中的JSON支持 Qt提供了处理JSON数据的支持.JSON是一种对源自Javascript的对象数据进行编码的格式,但现在已广泛用作 ...

  3. linux服务器返回json,Linux 命令行工具解析和格式化输出 JSON的方法

    JSON 是一种轻量级且与语言无关的数据存储格式,易于与大多数编程语言集成,也易于人类理解 -- 当然,如果格式正确的话.JSON 这个词代表 J ava S cript O bject N otat ...

  4. jq输出文本_如何用 Linux 命令行工具解析和格式化输出 JSON | Linux 中国

    我们将使用 Linux 上的命令行工具解析并格式化打印 JSON.它对于在 shell 脚本中处理大型 JSON 数据或在 shell 脚本中处理 JSON 数据非常有用.-- Ostechnix J ...

  5. 通过 nginx-lua 给 Nginx 增加 OAuth 支持

    前言:我们使用Nginx的Lua中间件建立了OAuth2认证和授权层.如果你也有此打算,阅读下面的文档,实现自动化并获得收益. SeatGeek 在过去几年中取得了发展,我们已经积累了不少针对各种任务 ...

  6. GMT5在linux下的中文支持

    GMT在linux下的中文支持 准备工作 gs 中文配置文件 GMT 字体配置文件 使gs支持中文 gs 中文配置文件 测试 gs 对 Linux 默认字体的支持 添加 Windows 中文字体 测试 ...

  7. Linux下mysql支持中文,linux下mysql环境支持中文配置步骤

    sql脚本执行前加上: CREATE DATABASE IF NOT EXISTS mydatabase DEFAULT CHARSET utf8 COLLATE UTF8_GENERAL_CI; u ...

  8. 【转载】Visual Studio 2015 for Linux更好地支持Linux下的开发

    原文:Visual Studio 2015 for Linux更好地支持Linux下的开发 英文原文:Targeting Linux Made Easier in Visual Studio 2015 ...

  9. linux系统最大支持多大硬盘容量,LINUX操作系统对硬件支持有上限么?最大多少内存?多大硬盘容量?...

    32位的Linux的内存最大支持到4GB,64位的Linux的最大支持内存在TB级别上. (实际上最大支持多大的内容跟操作系统的种类无关,而是跟操作系统是几位的.还有CPU是几位的有关.) DOS是1 ...

最新文章

  1. spring实现listener(转)
  2. 福大软工1816:项目测评
  3. 【运维技术】Zookeeper单机以及集群搭建教程
  4. Kafka消息模拟器
  5. 抚摸那条船——彭晓东
  6. C#读取Excel表格数据到DataGridView中和导出DataGridView中的数据到Excel
  7. 『操作系统』微内核结构的操作系统几何?(优缺点)
  8. mysqlclient==1.3.7对应mysql版本_「MySQL」CentOs 7 下安装MySQL
  9. 漫谈忠诚:猪八戒为什么总想离队
  10. linux查看svn信息,SVN 查看历史信息
  11. Django模型修改及数据迁移
  12. Filecoin官方提案FIP0013 添加批量提交ProveCommitSector以减少拥塞
  13. 24点游戏算法python_24点游戏算法
  14. 【安装配置】SAS9.4安装
  15. Redis高级特性RDB、AOF、事务、Stream、Pipeline和Lua脚本
  16. 【亲测有效】鼠标滚轮在下滑的时候总是上下乱窜解决办法
  17. ITX迷你主机的优点及缺点
  18. linux build文件,从源代码到可执行文件——编译全过程解析
  19. 【机器学习课程】 第一章机器学习概述 1.人工智能
  20. normal + lognormal

热门文章

  1. PHP读取excel表格内容 PHP-ExcelReader
  2. Flink 异步IO访问外部数据(mysql篇)
  3. 登录加密的前后端测试
  4. spring 基本配置学习
  5. CocosCreator游戏开发---菜鸟学习之路(三)如何在CocosCreator中使用Pomelo
  6. [51nod1384]全排列
  7. 最全的MySQL基础【燕十八传世】
  8. PAT (Basic Level) Practise:1017. A除以B
  9. 实现用户自定义Excel模板
  10. Linux 服务器安装discuz 7.2论坛