热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

ios-PHP传给app的JSON有什么要求?

我从数据库取出数据后发到web上,让APP去获取信息:{代码...}输出到界面的json为:{"hps_userid":"1","hps_userid2":"1"}现在app端无法获取数据是我的输出格式问题还是app那边的问题?现在app那边的同事说需要...
我从数据库取出数据后发到web上,让APP去获取信息:

$result = mysql_query("select * from his");
while ($arr = mysql_fetch_assoc($result)) {
    $json = json_encode($arr,JSON_UNESCAPED_UNICODE);
    echo $json;
}

输出到界面的json为:
{"hps_userid":"1","hps_userid2":"1"}
现在app端无法获取数据是我的输出格式问题还是app那边的问题?

现在app那边的同事说需要这种格式才可以

{"No.":[{"hps_userid":"1","hps_userid2":"1"}]}

当搜索到多条数据的时候,又要怎么如何输出?

回复内容:

我从数据库取出数据后发到web上,让APP去获取信息:

$result = mysql_query("select * from his");
while ($arr = mysql_fetch_assoc($result)) {
    $json = json_encode($arr,JSON_UNESCAPED_UNICODE);
    echo $json;
}

输出到界面的json为:
{"hps_userid":"1","hps_userid2":"1"}
现在app端无法获取数据是我的输出格式问题还是app那边的问题?

现在app那边的同事说需要这种格式才可以

{"No.":[{"hps_userid":"1","hps_userid2":"1"}]}

当搜索到多条数据的时候,又要怎么如何输出?

“现在app那边的同事说需要这种格式才可以”,“才可以”,哈哈。。。
以前我和别人合作的时候也听到过类似的说法,然而后来我学了安卓开发。。。
妈蛋的,才发现,明明是他们解析JSON的代码不怎么会写,还怪我给的格式不对。。。

只要输出的是标准的JSON格式,信息完整,组织正确,根本不存在解析不了的问题。

{"No.":[{"hps_userid":"1","hps_userid2":"1"}]}

这个"No"的存在并没有什么必要(只是因为他们JSON解析不太会)。
话说,“当搜索到多条数据的时候,又要怎么如何输出?"
这种问题应该一开始就考虑好,好吧?

[
    {
        "hps_userid": "1",
        "hps_userid2": "1"
    },
    {
        "hps_userid": "2",
        "hps_userid2": "3"
    },
    {
        "hps_userid": "4",
        "hps_userid2": "5"
    }
]

取多条数据,最后都保存到一个数组里,然后把数组转成JSON,就是上面这样的了。
话说你的代码怎么会是这样。。。

$result = mysql_query("select * from his");
while ($arr = mysql_fetch_assoc($result)) {
    $json = json_encode($arr,JSON_UNESCAPED_UNICODE);
    echo $json;
}

你知道while循环了几次吗?每次循环都echo,最后输出的是类似这样的:

{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}{"hps_userid":"1","hps_userid2":"1"}

这种连起来的就根本不是JSON字符串啊。。。
。。。。。。
如下:

$result = mysql_query("select * from his");
$Temp = array();
$row = mysql_fetch_assoc($result);
while ($row) {
    $Temp[] = array("hps_userid"=>$row["hps_userid"],"hps_userid2"=>$row["hps_userid2"]);
    $row = mysql_fetch_assoc($result);
}
die(json_encode($Temp));
//或者你就听你们那个逗比APP工程师的:
//die(json_encode(array("No."=>$Temp)));

这里是需要循环的,所以你给你们逗比工程师的json,是需要用 [{xxx:1},{xxx:2}] 这种格式的

推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • 单点登录原理及实现方案详解
    本文详细介绍了单点登录的原理及实现方案,其中包括共享Session的方式,以及基于Redis的Session共享方案。同时,还分享了作者在应用环境中所遇到的问题和经验,希望对读者有所帮助。 ... [详细]
  • 本文讨论了Kotlin中扩展函数的一些惯用用法以及其合理性。作者认为在某些情况下,定义扩展函数没有意义,但官方的编码约定支持这种方式。文章还介绍了在类之外定义扩展函数的具体用法,并讨论了避免使用扩展函数的边缘情况。作者提出了对于扩展函数的合理性的质疑,并给出了自己的反驳。最后,文章强调了在编写Kotlin代码时可以自由地使用扩展函数的重要性。 ... [详细]
  • 使用正则表达式爬取36Kr网站首页新闻的操作步骤和代码示例
    本文介绍了使用正则表达式来爬取36Kr网站首页所有新闻的操作步骤和代码示例。通过访问网站、查找关键词、编写代码等步骤,可以获取到网站首页的新闻数据。代码示例使用Python编写,并使用正则表达式来提取所需的数据。详细的操作步骤和代码示例可以参考本文内容。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • React项目中运用React技巧解决实际问题的总结
    本文总结了在React项目中如何运用React技巧解决一些实际问题,包括取消请求和页面卸载的关联,利用useEffect和AbortController等技术实现请求的取消。文章中的代码是简化后的例子,但思想是相通的。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 如何查询zone下的表的信息
    本文介绍了如何通过TcaplusDB知识库查询zone下的表的信息。包括请求地址、GET请求参数说明、返回参数说明等内容。通过curl方法发起请求,并提供了请求示例。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • 在Android中解析Gson解析json数据是很方便快捷的,可以直接将json数据解析成java对象或者集合。使用Gson解析json成对象时,默认将json里对应字段的值解析到java对象里对应字段的属性里面。然而,当我们自己定义的java对象里的属性名与json里的字段名不一样时,我们可以使用@SerializedName注解来将对象里的属性跟json里字段对应值匹配起来。本文介绍了使用@SerializedName注解解析json数据的方法,并给出了具体的使用示例。 ... [详细]
author-avatar
arliejun
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有