2014年,移动APP的热度丝毫没有减退,并没有像桌面软件被WEB网站那样所取代, 
不但如此,越来越多的传统应用、网站也都开始制作自己的移动APP,也就是我们常说的IOS客户端、android客户端。 
这仿佛又回到了多年前的CS架构,那时候我们用VB、VC、Delphi在Windows平台上快速开发各种应用程序。 
不同的是,如今的移动端APP基本上都是联网从服务器端获取各种数据,客户端只是一个简单的表现层的工具。

不仅仅是移动APP,包括面向服务的SOA架构,都需要制定一套统一、规范的接口, 
那么,做这样的后端接口需要注意哪些问题呢?

1、跨平台性

所谓跨平台是指我们的接口要能够支持不同的终端,比如android、ios、windowsphone以及桌面软件、网站等,
一套接口,支持多端,就像当年Java的口号一样“Write Once,Run Anywhere”。 
当然从本质上讲,服务器端的接口跟终端是没有太大关系的,只是接口应该考虑到不同端的接入成本, 
采用通用的解决方案,比如通信协议就采用最常用的HTTP协议,如果是即时通信,可以采用开放的XMPP协议, 
做游戏的可以采用可靠的TCP协议,除非TCP不够用了,再采用定制的UDP协议。 
数据交换采用xml或者json格式等等。 
总之,要达到的目标就是让不同的端能够很方便的使用你的接口。

2、良好的响应速度

如果要用一个指标来衡量接口的性能的话,那么我想最重要的就是响应速度了。 
接口应该以最快的速度将数据返回给请求者。 
试想,当我们打开一个页面,如果“努力加载中”之类的提示超过三五秒钟的话, 
我们肯定会变得不耐烦,移动app本来大部分就是用户在碎片化时间来使用的, 
在有限的时间内,用户恨不得获得的信息越多越好,即使你的app界面设计的再好,用户也不会买账。

提高响应速度又是个老生常谈的问题,大体上应该按照以下步骤来做: 
初期,以功能为主,要保证功能完整,满足业务需求,这阶段可以使用动态的语言,比如java、php、asp.net等, 
配合设计良好的数据库结构和索引,能满足一定的需求; 
其次,随着用户的增多,可以考虑一些缓存方案,缓存是解决性能问题的万金油,通常能起到立竿见影的效果。  
最常用的静态文件缓存,memcached内存缓存等。 
然后,单台机器的吞吐率不行了,通过负载均衡多加几台机器就行了。七八台机器,支持每天千万级的接口调用是可行的。 
或者,直接采用CDN的解决方案,将绝大多数的静态资源交给CDN去处理。

总之,要达到的目标就是快,一个页面,秒开最好,超过三秒就需要找找原因了。

3、接口要为移动客户端考虑

接口不仅仅是提供数据和功能就完事了,更应该充分考虑移动端的特性,为移动端提供更加方便、快捷的接口。 
比如,在移动端里,下拉刷新和上拉加载更多是很常见的功能,如果接口仍然按照传统的web思路, 
只提供按页读取的话,就会造成移动端的额外的数据请求和计算。 这时,接口就应该针对这两种类型的操作提供额外的支持。

再比如,对于一个新闻阅读类的app来说,最新的新闻列表里的文章,特别是前几条,用户很容易点击进去看, 
而后面的老的文章列表,一来用户下滑加载好几页的情况较少,二来过时的新闻用户也很少点。 
如果,接口在返回新闻列表时,对于最新的列表,可以直接把文章的正文(或者部分正文,比如一屏的内容)信息一起传给客户端, 
这样,用户在打开新闻详情页的时候,就不用再从服务器端获取了,自然可以做到秒开。

比如访问第一页时,接口可以返回文章内容,如下所示 ,content=1表示加载文章内容 
newslist?page=1&pagesize=20&content=1 
其他页时,newslist?page=5&pagesize=20&content=0 ,不用加载文章内容。

当然,客户端要跟接口做好配合,搭配好,才能最大化的提高性能。 
比如,移动端都有左右滑动来看上一篇、下一篇文章或者图片的功能, 
如果,当用户请求某篇文章的时候,服务器端顺便也把下一篇文章的内容返回回来了,

那么当用户看下一篇的时候,是不是就很快了呢。

当然这种preload的方案也不能滥用,如果预加载数据的命中率较低的话,也不行,白白浪费了很多的流量。

4、考虑移动端的网络情况和耗电量

如果让我们说出哪类app比较好,可能还不大好说,但是如果让我们说出哪些app很差, 
我们肯定会说出那些 体积很大、占用内存多、界面很卡、费电的app不好。

对于移动APP开发者来说, 网络流量和电池电量是不得不考虑的问题。 
不过,您也许会说,这些跟接口没啥关系吧,服务器端的接口还能管得了客户端的网络流量和电量?

对于网络情况,接口应该具备为不同的网络提供不同的内容的能力, 
通常,移动端的上网方式无非是2G(GSM、GPRS、EDGE)、3G(CDMA、TDSCDMA、WCDMA)、WIFI, 
设想一下,如果用户在流量需要花钱的情况下,你的app给用户展示了视频、音频、大量的图片而没有通知用户的情况下, 
用户会怎么想,毕竟国内的流量费用还是很贵的。 
还以上面的新闻列表接口为例,如果我们能够知道用户的网络情况,只有在wifi的情况下才给用户传输封面图、缩略图之类的, 
是不是可以帮用户节省很多流量呢。 
newslist?page=1&pagesize=20&content=1&network=wifi

对于电量,首先我们要弄清楚,app的哪些方面会消耗电量? 
比如app有大量的计算、有很炫的视觉画面都会消耗电量, 另外,不断的移动网络链接也会消耗大量的电量, 
我们都知道移动网络是通过无线电波来通讯的,那么发射装置就需要消耗一定的电量来发射和接收无线信号。 
特别的是,频繁的链接会不断的切换网络设备与移动基站之间连接状态,这都会消耗一部分电量。

所以,对于接口而言,尽量用少的链接传输多的数据, 
比如,对于关于我们、版本更新以及一些系统配置信息,完全可以通过一次链接全部返回给客户端。

5、通用的数据交换格式

目前,对于接口和客户端的数据交换格式,基本上就是两种,xml和json,而现在使用json的应该占大多数。 
交换的数据包括两种,一种是客户端请求服务器端接口时传递的一些参数,一种是服务器端返回给客户端的数据。

对于客户端的请求参数,现在也越来越多的接口要求采用json的格式,而不是以往最常见的key_value对了。 
比如,接口需要username和password两个参数 
key_value pair的方式是: 
username=hutuseng&password=hutusengpwd 
然后通过GET或者POST方式传送。 
而通过json方式交换数据的话,格式如下,直接POST到服务器端。 

'username':'hutuseng', 
'password':'hutusengpwd' 
}

对于服务器端返回的json数据格式,需要注意两个问题: 
一是汉字编码问题,因为json(javascript)内部支持Unicode编码,会将汉字等转换成unicode编码保存,  
所以在返回结果中,对于中文,可以直接输出中文,也可以输出中文的unicode编码, 
json解析器都会很好的解析。  
比如下面两种方式都是可以的。 
{"code":"208","data":"\u53c2\u6570\u4e0d\u5b8c\u6574"}  

"code": "208", 
"data": "参数不完整" 

二是字段的数据类型,特别是数字类型的,json中尽量转成数字格式, 
比如 

'userid':128 

不要写成 

'userid':'128' 
}

6、接口统计功能

在做PC端网站的时候,我们都会给我们的网站加上个统计功能,要么自己写统计系统,要么使用第三方的比如GA、百度等。 
移动端接口API则需要我们自己实现统计功能, 
这时就需要我们尽可能多的收集客户端的信息,除了传统的IP、User-Agent之外,还应该收集一些移动相关的信息, 
比如 
手机操作系统,是android还是ios,都是什么版本, 
用户使用的网络状况,是2G、3G、4G还是WIFI 
客户端APP是什么版本信息。

这样,有助于我们更好的了解我们用户的使用情况。

7、客户端与服务端的肥瘦平衡

在以前C/S、B/S架构时,我们就已多次讨论过这个问题,客户端是瘦点好还是肥点好,当然也没有固定答案,需要自己根据实际情况去做权衡。 
但是,在移动开发中,由于客户端的修改会很费时费力,特别是IOS应用还要经过Apple审核, 
另外,当前IOS开发人员、Android开发人员的人工成本普遍较高,人才紧缺, 
基于这两点,能在服务器端实现的功能就不要放在客户端,毕竟服务器端程序的修改要比客户端方便、灵活、快捷的多。

8、隐式用户与显式用户

显式用户和隐式用户,我不知道这两个词用的是否确切。  
显式用户指的是,APP程序中有用户系统,一个username、password正确的合法用户,称之为显式的用户, 
通常显式用户都需要注册,登录以后能完成一些个人相关的操作。

隐式用户指的是,APP程序本身就没有用户系统,或者一个在没有登录的情况下,使用我们APP的用户。 
在这种情况下,可以通过客户端生成的UDID来标识一个用户。

有了用户信息,我们就能够了解不同用户的使用习惯,而不仅仅是全体用户的一个整体的统计信息, 
有了这些个体的信息之后,就可以做一些用户分群、个性化推荐之类的事情。

9、安全问题

网络安全已经从桌面互联网转到了移动互联网,从客户端蔓延到了接口API中。

传统固若金汤的网站,很可能因为接口的一点疏忽而遭受入侵。现在,在很多白帽子或者黑客的入侵思路中,

先看看移动端接口是否存在漏洞,再看网站是否有漏洞。

客户端APP与接口的通信很容易被得到,只要在中间路由上嗅探一下就行, 
whireshark、tcpdump这类工具使得这项工作变得简单无比。

所以,接口的安全工作不能马虎,暴力破解啊、SQL Injection啊、伪造请求和数据啊、重复提交啊也要考虑到, 
如果数据特别敏感,可以考虑采用SSL/TLS等加密传输,或者客户端、服务器端约定一个加密算法和密钥,对来往传输的数据进行加密、解密 
如果不采用RESTful API,可以采用基于WSDL和SOAP的Web Service的安全措施。

10、良好的接口说明文档和测试程序

接口文档有时候是项目初期就定下来的,前后端开发人员按照接口规范开发,
有的是接口开发完成后写的。
接口文档要清晰、明了,包含多少个接口,每个接口的地址、参数、请求方式、数据交换格式、返回值等都要写清楚。

接口测试程序,有条件的话,也可以提供,方便前后端的调试。

11、版本的维护

随着业务的变化,客户端APP和服务器端API都会发生变化,增加新的功能,修改已有的功能, 
增加功能还好说, 如果是接口需要修改,那么就面临着同一个接口要同时为不同版本的客户端服务的问题。 
因此,服务器端接口也要做好相应的版本维护。

APP后端数据接口注意事项相关推荐

  1. 工作26:后端数据接口问题

  2. 微信小程序 - 在自定义组件中请求后端 API 数据接口(引入该组件的页面触发)组件在哪个生命周期钩子函数中请求接口数据呢?

    前言 我开发了一个 A 页面,然后在 A 页面引入了一个组件 B ,我想在 B 组件中加载进来的时候执行一个后端请求,获取数据进行 B 组件渲染. 今天遇到这么一个问题,我写好的小程序 组件(comp ...

  3. 循序渐进BootstrapVue,开发公司门户网站(5)--- 使用实际数据接口代替本地Mock数据

    在我们开发一些门户网站功能的时候,有时候我们需要快速的创建数据模型来进行数据展示,因为数据结构可能处于不断的修正变化之中,因此服务端的接口我们可以暂时不开发,当我们基本完成数据结构和界面展示的时候,就 ...

  4. app后端开发一:swagger-ui教程-构建api接口文档工具

    声明 之前写过关于app后端开发的一系列文章,那是我第一次做app后端开发,存在很多不足,本想好好修改一下,想想还是重新写吧,这样子也能让我博客文章看起来多一点嘛,万一以后找工作,别人一看我博客这么多 ...

  5. 【京东API】京东app获得JD商品详情原数据接口

    京东是中国最大的综合型电商网站之一,其app端是用户购买商品的主要途径之一.为了更好地满足用户的需求,开发人员提供了商品原数据接口,让第三方开发者可以获取京东商品的详细信息. 开发背景: 随着移动设备 ...

  6. 关于App开发:模拟服务器数据接口 - MockApi

    为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...

  7. 猫眼电影App抓包获取评论数据接口

      之前在CSDN程序人生公众号上看到了这篇文章<邪不压正>评分持续走低,上万条网友评论揭秘,是救救姜文还是救救观众?,文中提到了通过抓包猫眼App发现了评论的数据接口:http://m. ...

  8. 淘宝app商品详情原数据接口V1新版接口

    item_get_app-获得淘宝app商品详情原数据接口,包括:标题,价格,促销价,优惠券,库存,销量,详情图片,SKU属性,主图等看的到的信息均可以拿到,可应用于商品销售情况分析,电商选品分析,品 ...

  9. 京东商品详情APP原数据API接口-(item_get_app-获得JD商品详情原数据API接口),京东API接口

    一.京东商品详情APP原数据API接口-(item_get_app-获得JD商品详情原数据API接口),京东API接口代码如下: 1.公共参数 名称 类型 必须 描述 key String 是 调用k ...

最新文章

  1. laravel的日志服务
  2. PostgreSQL学习手册(七) 事物隔离
  3. Linux新手入门:通过chmod改变文件权限--转
  4. Redis的搭建和Redis的集群搭建
  5. ImageLightbox.js – 响应式的图片 Lightbox 插件
  6. Python 链接汇总
  7. 转-Apache kafka 工作原理介绍
  8. docker删除所有镜像和容器
  9. 稀疏数组(数据结构)
  10. Java使用继承的语法是,Java基础语法八 继承
  11. rust实现wss访问_Rust的所有权,第2部分
  12. 洛谷P1122最大子树和题解
  13. linux 系统配置
  14. LeetCode 229 : Majority Element II
  15. Web UI自动化测试之元素定位
  16. QTP软件测试工具学习
  17. 【NLP】千呼万唤始出来——GPT-3终于开源!
  18. c/c++实现简单的贪吃蛇可视化游戏
  19. 秒解UTF-8带来的烦恼
  20. java环境变量win7_win7如何配置jdk环境变量|win7配置java环境变量的方法

热门文章

  1. 教育|仝卓高考舞弊案细节曝光:为“恢复高考成绩”已起诉1年多
  2. 一个前端的入行故事,零基础,2个月自学入门前端,半年从外包进淘宝
  3. python数据挖掘学习笔记】十四.Scipy调用curve_fit实现曲线拟合
  4. Elon Musk: The mind behind Tesla, SpaceX, SolarCity
  5. SQL Server 2012 管理新特性:AlwaysOn
  6. Python一亿以内的素数个数_Python 计数质数
  7. Model 3车主对FSD套件不满意 德国法院下令特斯拉回购汽车
  8. 抖音升级老年人防沉迷提醒机制 覆盖多个使用场景
  9. 卢伟冰为Redmi K50电竞版预热:相机拍照效果越来越出色
  10. 男子花41万买手镯,被店员议论“买不起” 气到要住院