json_encode在设计api时需要注意的问题

在设计api时我们经常会使用关联数组,例如:我要返回给客户端主题信息和主题包列表

原始数组格式

$arr = array(
    100=>array(‘themeName‘=>‘a‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
    200=>array(‘themeName‘=>‘b‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
    300=>array(‘themeName‘=>‘c‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
);

我们希望返回给客户端这样的数据

[
  {‘themeName‘=>‘a‘, files:[1.rar,2.rar]},
  {‘themeName‘=>‘b‘, files:[1.rar,2.rar]},
  {‘themeName‘=>‘c‘, files:[1.rar,2.rar]},
]

而json_encode给我们的是这样的数据

{
  ‘100‘=>{‘themeName‘=>‘a‘, files:[1.rar,2.rar]},
  ‘200‘=>{‘themeName‘=>‘b‘, files:[1.rar,2.rar]},
  ‘300‘=>{‘themeName‘=>‘c‘, files:[1.rar,2.rar]},
}

在php中的数字索引数组对应js的[],关联数组对应js的{},看两个示例

php数值索引数组

$arr = array(1,2,3);
echo json_encode($arr);

output

[1,2,3]

php关联数组

$arr = array(1=>array(1,2,3),2=>array(4,5,6),3=>array(7,8,9));
echo json_encode($arr);

output

{"1":[1,2,3],"2":[4,5,6],"3":[7,8,9]}

要解决这个问题需要把“关联数组”转换成“数字数组”,例如

$arr = array(
    100=>array(‘themeName‘=>‘a‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
    200=>array(‘themeName‘=>‘b‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
    300=>array(‘themeName‘=>‘c‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
);
$arr = array_merge(array(),$arr);
echo json_encode($arr);

使用array_merge函数和空数组合并就可以转换成数组数组了,这种方法的好处是可以保留数组的原始顺序

output

[{"themeName":"a","files":["1.jpg","2.jpg"]},{"themeName":"b","files":["1.jpg","2.jpg"]},{"themeName":"c","files":["1.jpg","2.jpg"]}]

也可以使用shuffle把数组打乱,但这样会破坏数组的顺序,例如

$arr = array(
    100=>array(‘themeName‘=>‘a‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
    200=>array(‘themeName‘=>‘b‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
    300=>array(‘themeName‘=>‘c‘,‘files‘=>array(‘1.jpg‘,‘2.jpg‘)),
);
shuffle($arr);
echo json_encode($arr);
时间: 2024-11-05 10:30:17

json_encode在设计api时需要注意的问题的相关文章

Atitit.自定义存储引擎的接口设计 api 标准化 attilax 总结  mysql

Atitit.自定义存储引擎的接口设计 api 标准化 attilax 总结  mysql 1. 图16.1:MySQL体系结构1 2. 16.7. 创建表create()虚拟函数:2 3. 16.8. 打开表 open()2 4. ---------------------------------------------------------------------------------------------------------------------2 5. 16.9. 实施基本的

用产品思维设计API(一)——RESTful就是个骗局

用产品思维设计API(一)--RESTful就是个骗局 前言 最近公司内部在重构项目代码,包括API方向的重构,期间遇到了很多的问题,不由得让我重新思考了下. - 一个优雅的API该如何设计? - 前后端分离之后,API真的解耦分离了吗? - 不断的版本迭代,API的兼容性该如何做? 年前,我司内部的接口已经进入了一个完全的重构阶段,参考了市面上各大平台的API和文档,自己也总结出了很多的心得.这里向大家分享一下,接下来一个月,我们向从下面几个方面向大家介绍一个优雅的API(至少我认为挺优雅)该

用产品思维设计API(二)——数据解耦,才是前后分离的本质

用产品思维设计API(二)--数据解耦,才是前后分离的本质 前言 最近公司内部在重构项目代码,包括API方向的重构,期间遇到了很多的问题,不由得让我重新思考了下. - 一个优雅的API该如何设计? - 前后端分离之后,API真的解耦分离了吗? - 不断的版本迭代,API的兼容性该如何做? ps.这里所说的API仅为Web API,提供APP\WEB开发使用. 年前,我司内部的接口已经进入了一个完全的重构阶段,参考了市面上各大平台的API和文档,自己也总结出了很多的心得.这里向大家分享一下,接下来

14.app后端如何设计api

app和后端的交互,一般都是通过后端提供的api实现.api的设计,估计很多刚进入app后端的小伙伴会一无头绪,不知道怎么入门.下面根据自己3年的app后端经验,总结出下几个api设计原则,给小伙伴参考. 1. 什么是api? 这个问题在以前发表的文章"7.app和app后端的通讯"中其实已经回答了,这里再重复一次. 相信大家都用过银行的柜员机(ATM)的查询余额,转帐,取款等操作. 当在柜员机取款的时候,我们输入要取款的金额,隔一会钱就出来了,如果因为有什么问题不能取款(例如超过取款

用产品思维设计API(三)——版本控制,没有你想的这么简单

用产品思维设计API(三)--版本控制,没有你想的这么简单 前言 最近公司内部在重构项目代码,包括API方向的重构,期间遇到了很多的问题,不由得让我重新思考了下. - 一个优雅的API该如何设计? - 前后端分离之后,API真的解耦分离了吗? - 不断的版本迭代,API的兼容性该如何做? ps.这里所说的API仅为Web API,提供APP\WEB开发使用. 年前,我司内部的接口已经进入了一个完全的重构阶段,参考了市面上各大平台的API和文档,自己也总结出了很多的心得.这里向大家分享一下,接下来

在设计IOSapp时为了代码的扩展性可可维护性需要遵守的原则

作为软件工程范畴的iosApp,为了保持代码的可维护性和扩展性,必然要遵守软件的基本特性,众所周知高内聚低耦合的程序才能具备这样的特性. 首先,不能依赖于storyboard和xib,原显而易见.第一点是,在源代码管理方面,在团队项目中,一旦有人改变了一点内容storyboard就会显示modify的样子,所以让人看起来很不安,其实带着M的原因很可能就是其他团队成员鼠标手点击了一下而已,最新的源代码管理工具在Xcode中的集成基本上解决了这个问题,但是依然还是会产生严重的代码冲突,这不是团队人员

[webapi] 如何在查看api时 显示api的说明

首先在Controller的方法中 写上相关注释,如下图 然后 右击webapi项目点属性.按照下图选择 红色框中内容要保持一致 然后保存. 在项目中找到到这个文件Areas/HelpPage/App_Start/HelpConfig.cs 双击打开,按照下图进行修改 然后预览此项目 路径 http://localhost:10643/Help 点击链接进去后 [webapi] 如何在查看api时 显示api的说明

C#设计界面时,未将对象引用设置到对象实例问题解决方案

在做.Net项目时,经常遇到在设计界面时,出现未将对象引用设置到对象实例问题,下面给出解决方案: 1.对于Winform和Asp.Net的界面设计可以按如下操作: Winform项目: protected override void OnLoad(EventArgs e) { base.OnLoad(e); if (string.Compare(Process.GetCurrentProcess().ProcessName, "devenv") == 0) return; //其他相关

程序开发使用地图API时需注意的问题(转)

最近在做一个基于地点提醒的移动应用,当初考虑大家都心知肚明的原因,谨慎的选择了百度地图,现在想想其实完全没有必要,好的应用本来就不分国界的,最后可能还是得换回Google地图.毕竟Google地图在技术和成熟度上完胜百度地图,当然百度也在慢慢追赶,希望有一天大家都能用上咱们自己的好用的地图服务. 现在把碰到的问题和解决方案罗列一下: 版权:如果是大量商用的话,还是得事先注意一下版权意识,不然到时候就很被动了.两者的免费版都不允许商业应用,具体可以看这里Google Maps API,百度API常