APP开发实战8-API接口设计(api接口应用)
moboyou 2025-07-27 19:48 2 浏览
接口设计
(1)需要确定APP和服务器间用什么格式传输数据,常用的有两种:XML和Json。XML文件中存在大量的描述信息,会大大增加网络传输数据;同样的内容,用Json格式,传输的数据比较少,首选Json格式。
还有一种Protocol Buffers格式,以二进制的方式传输存储数据,网络传输数据量比Json还少,但要使用proto文件作为格式验证,各语言需要整一堆pb runtime以及对应的代码生成,增加复杂度较高,目前使用的不多。
(2)需要设计Json数据的具体格式:
发送请求(无具体参数)
发送请求(有非数组格式的具体参数)
发送请求(有数组格式的具体参数)
操作成功(只返回操作状态,不返回数据)
操作成功(返回操作状态和非数组数据)
操作成功(返回操作状态和数组数据)
操作失败(只返回操作状态和出错提示)
在定义Json中的字段名称时,尽量短小,以减少网络传输数据。
(3)APP端解析Json格式时,最好采用严格模式,只要从服务器传来的Json数据,和约定的不一致,无论是多字段、少字段还是字段名称变了,APP端都应报错,这样有利于早发现问题。
(4)因为服务器端的接口代码可能会发生变化,所以在APP端向服务器端发送请求时,最好把接口的版本号也带上。
如已经上线的旧APP中使用的接口版本是1.0,在上线后接口更新到1.1版本,而且不兼容1.0版本,用户有可能不更新APP,还是使用旧版本APP。
服务器端接收到请求后,发现APP使用的接口版本是1.0,就可以调用旧接口处理APP请求;如果请求中不带版本号,遇到这种状况,就很难处理了。
(5)APP往往需要从服务器获取图片,但服务器的图片往往不完全适合APP需要,就需要先在服务器端按APP的需要处理图片,然后把处理过的图片传给APP; APP在发送获取图片的请求时,把所需图片的宽度和高度发给服务器,如采用GET命令,可以按以下方式:
http://www.hello.com/getimage/2/width/100/hight/100
服务器收到请求,就可按APP要求的尺寸处理图片,并发给APP。
(当然也可以用POST命令实现)
(6)大多数APP和服务器交互时用HTTP协议,也就是短连接:每向服务器发送一个请求都要先建立连接,传输数据,然后再断开连接;即使服务器端有做连接池设计,但连接池中容纳的连接个数有限制。
在设计接口时,在APP端执行的每一个动作,尽量做到只需向服务器发送一次请求;也要减少APP在显示新页面时,发送请求的次数,以减少APP和服务器建立连接和断开连接消耗的时间及资源,提高程序响应速度。
(7)对于向APP返回数组数据的接口应设计支持分页操作,提供参数供APP端设置获取元素的起始位置和获取的个数:
数组中有100个元素,但APP端可能第一次从第1个元素开始只获取10个元素,第二次从第11各元素开始只获取5个元素。
如电商APP中获取商品列表和订单列表等就需要这样设计。
(8)服务器端采用的语言即有Java这样的强类型语言,也有PHP这样的弱类型语言,有些后台同事很喜欢使用字符串类型,导致APP端常会遇到类型出错的问题,本来需要整型数据,结果服务器传的是字符串。
为解决这类问题,在和服务器端定义字段的数据类型时,除了在APP端会涉及到数学的加、减、乘、除或比较大小运算的字段外,其余的字段都定义成字符串类型;或把所有字段都定义成字符串,APP内部把字符串转换成整型或浮点型。
相关推荐
- CentOS、Nginx、PHP、MySQL的安装和配置记录
-
安装LNMP安装wget工具(可选) yuminstall-ywget下载Nginx wgethttp://www.atomicorp.com/installers/ato...
- phpstudy安装及简单使用教程(phpstudy pro怎么安装)
-
phpstudy前不久爆出有后门,我的看法是,去看下是哪个版本有后门,为啥会有后门,怎么解决掉这个后门,而不是听到后门就弃用了。毕竟phpstudy绿色安装,配置简单,多版本融合,真香。前言:关于开发...
- PHP 语法详解(php方法大全)
-
PHP脚本在服务器上执行,然后向浏览器发送回纯HTML结果。基础PHP语法PHP脚本可放置于文档中的任何位置。PHP脚本以<?php开头,以?>结尾:<?php...
- 简单一点 全网页截图不难(网页截图如何截完整的)
-
很多人看到好的网页想要截图,比如看到一个全屏幕网页很好,想要截取下来保存,无论如何都是快捷键或者Windows自带的截图工具无法实现的,通常方法都是安装专用的截图软件,占用系统空间不说,专业的软件操作...
- PHP分享(php分享IPTV单播步骤详解和注意事项)
-
第一次接触PHP,这是我做的输出和符不符合条件,第三个我忘记叫什么了,对这个还不太熟悉,要勤加练习。左边是代码,右边是效果图。我在做的时候出现最多的错误就是符号,写代码一定要切记是在英文状态下写不是在...
- PHP站点要这样配置服务器才安全(php 服务器配置)
-
主机(站点)配置一个站点的2个核心信息为:主机名(服务器名/站点名):ServerName服务器名站点位置(站点目录路径):DocumentRoot“实际物理路径”默认情况下,apache安装...
- 从零学习php之php语法——课程1(php教程200课程)
-
以后将会每天更新一篇电脑编程教程有需要的朋友记得订阅转发哟怎么学习php?对于想学php还没入门的朋友很多都在纠结怎么开始第一步。我很了解php初学者的心理,因为我也是从那个阶段过来的,也是自学。那...
- 为什么使用PHP制作网站?(php为什么可以开发动态网页)
-
现在网站制作可以使用多种语言。为什么我们选择PHP进行网站制作?北京东浩联创科技有限公司.是一家高端网站制作公司,在业界处于领先地位。本文东浩联创的小编告诉大家我们为什么使用PHP进行网站制作?它的...
- 更新:PHP 8.2.11(64位)(更新:PHP 8.2.11(64位破解)
-
最新版本:PHP8.2.11(64位)最新消息:WindowsXP64/Vista64/Windows764/Windows864/Windows1064/Wind...
- 常见的PHP五大运行模式详解(php运行需要哪些核心程序)
-
1)CGI(通用网关接口/CommonGatewayInterface)2)FastCGI(常驻型CGI/Long-LiveCGI)3)CLI(命令行运行/CommandLineI...
- 常见36种WEB渗透测试漏洞描述及解决方法---phpinfo信息泄露
-
漏洞描述:测试页面可能会使用到PHP的phpinfo()函数输出服务器重要信息,造成信息泄露,为后续攻击提供可能。解决方法:删除相关PHP文件。...
- 跨境电商独立站必做!隐藏PHP版本的小秘密
-
你知道吗?黑客攻击独立站的第一步,往往是“侦察”。就像小偷会先踩点一样,他们会扫描你的服务器信息,而暴露的PHP版本就是最显眼的“漏洞地图”。有个卖家居的跨境卖家曾跟我吐槽:“网站莫名其妙被注入恶意代...
- 对不起,您访问的页面不存在!(出错啦!你访问的页面不存在...)
-
可能因为:网址有错误>请检查地址是否完整或存在多余字符网址已失效>可能页面已删除,活动已下线等...
- php搭建小型部门网站(php建一个网站步骤)
-
熟悉前端html,js,css,后端熟悉php,python,java只能称得上一般,还有很多坑待踩。鉴于所学很杂,决定利用对业务的熟悉来搞一个部门网站来简化大家的工作流程。初步设计方案后端用p...
- 如何知道网站是否用PHP语言编写的
-
最近一段时间,有好多朋友问我,这个商城是不是用的PHP程序,那个网站用的是不是PHP程序,特别是刚入行的新人,那么如何判断一个网站是不是用语言写的,这还真是个问题,那么今天我就以我的经验写一下通过网...
- 一周热门
- 最近发表
- 标签列表
-
- 外键约束 oracle (36)
- oracle的row number (32)
- 唯一索引 oracle (34)
- oracle in 表变量 (28)
- oracle导出dmp导出 (28)
- oracle两个表 (20)
- oracle 数据库 字符集 (20)
- oracle安装补丁 (19)
- matlab化简多项式 (20)
- 多线程的创建方式 (29)
- 多线程 python (30)
- java多线程并发处理 (32)
- 宏程序代码一览表 (35)
- c++需要学多久 (25)
- css class选择器用法 (25)
- css样式引入 (30)
- css教程文字移动 (33)
- php简单源码 (36)
- php个人中心源码 (25)
- php小说爬取源码 (23)
- 云电脑app源码 (22)
- html画折线图 (24)
- docker好玩的应用 (28)
- linux有没有pe工具 (34)
- mysql数据库源码 (21)