Linux PHP增加JSON支持及如何使用JSON
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相关推荐
- mysql操作json优点和缺点_MYSQL 5.7中的本机JSON支持:MYSQL中JSON数据类型的优缺点是什么?...
在MySQL 5.7中,新的数据类型用于在JSON表中存储JSON数据. 添加. 显然,这将是MySQL的巨大变化. 他们列出了一些好处 Document Validation - Only vali ...
- Qt中的JSON支持
Qt中的JSON支持 Qt中的JSON支持 概述 JSON类 Qt中的JSON支持 Qt提供了处理JSON数据的支持.JSON是一种对源自Javascript的对象数据进行编码的格式,但现在已广泛用作 ...
- linux服务器返回json,Linux 命令行工具解析和格式化输出 JSON的方法
JSON 是一种轻量级且与语言无关的数据存储格式,易于与大多数编程语言集成,也易于人类理解 -- 当然,如果格式正确的话.JSON 这个词代表 J ava S cript O bject N otat ...
- jq输出文本_如何用 Linux 命令行工具解析和格式化输出 JSON | Linux 中国
我们将使用 Linux 上的命令行工具解析并格式化打印 JSON.它对于在 shell 脚本中处理大型 JSON 数据或在 shell 脚本中处理 JSON 数据非常有用.-- Ostechnix J ...
- 通过 nginx-lua 给 Nginx 增加 OAuth 支持
前言:我们使用Nginx的Lua中间件建立了OAuth2认证和授权层.如果你也有此打算,阅读下面的文档,实现自动化并获得收益. SeatGeek 在过去几年中取得了发展,我们已经积累了不少针对各种任务 ...
- GMT5在linux下的中文支持
GMT在linux下的中文支持 准备工作 gs 中文配置文件 GMT 字体配置文件 使gs支持中文 gs 中文配置文件 测试 gs 对 Linux 默认字体的支持 添加 Windows 中文字体 测试 ...
- Linux下mysql支持中文,linux下mysql环境支持中文配置步骤
sql脚本执行前加上: CREATE DATABASE IF NOT EXISTS mydatabase DEFAULT CHARSET utf8 COLLATE UTF8_GENERAL_CI; u ...
- 【转载】Visual Studio 2015 for Linux更好地支持Linux下的开发
原文:Visual Studio 2015 for Linux更好地支持Linux下的开发 英文原文:Targeting Linux Made Easier in Visual Studio 2015 ...
- linux系统最大支持多大硬盘容量,LINUX操作系统对硬件支持有上限么?最大多少内存?多大硬盘容量?...
32位的Linux的内存最大支持到4GB,64位的Linux的最大支持内存在TB级别上. (实际上最大支持多大的内容跟操作系统的种类无关,而是跟操作系统是几位的.还有CPU是几位的有关.) DOS是1 ...
最新文章
- spring实现listener(转)
- 福大软工1816:项目测评
- 【运维技术】Zookeeper单机以及集群搭建教程
- Kafka消息模拟器
- 抚摸那条船——彭晓东
- C#读取Excel表格数据到DataGridView中和导出DataGridView中的数据到Excel
- 『操作系统』微内核结构的操作系统几何?(优缺点)
- mysqlclient==1.3.7对应mysql版本_「MySQL」CentOs 7 下安装MySQL
- 漫谈忠诚:猪八戒为什么总想离队
- linux查看svn信息,SVN 查看历史信息
- Django模型修改及数据迁移
- Filecoin官方提案FIP0013 添加批量提交ProveCommitSector以减少拥塞
- 24点游戏算法python_24点游戏算法
- 【安装配置】SAS9.4安装
- Redis高级特性RDB、AOF、事务、Stream、Pipeline和Lua脚本
- 【亲测有效】鼠标滚轮在下滑的时候总是上下乱窜解决办法
- ITX迷你主机的优点及缺点
- linux build文件,从源代码到可执行文件——编译全过程解析
- 【机器学习课程】 第一章机器学习概述 1.人工智能
- normal + lognormal