摘要:总结一下数据保护的技术点参数传输使用密文,可以使用对称加密非对称加密或者两者的结合,比如请求就是属于两者结合的方式。安全性一些常用的安全问题都要考虑到,并且在项目框架底层进行防范,例如攻击注入问题单用户或者单的访问频率控制来进行防攻击。
App所有数据都来源于服务器,App和服务器交互普遍是采用http请求接口的方式,那么在搭建和维护一个后端Api项目时候需要注意哪些问题呢?
1. 数据保护数据保护做的好不好,有两个原则来验证:
第一,可以控制让谁来读取数据,
对于任何一个Api项目其实就是只允许产品App本身访问,这就需要用密文传输请求数据,做到即使被人用抓包工具抓到请求数据也没有办法解析出参数的意义。
把安全做到更近一步,可以在加密之前引入timestamp参数,在服务端通过比较timestamp和当前时间戳可以做到对于抓取到的链接也不能重复调用。
密文的安全性取决于参数的加密方式,使用对称加密、非对称加密或者两者结合取决于团队自己的选择,当然如果接口域名已经配了证书支持https,就不用自己写代码来做这些事情了。
如果密文传输已经做到绝对安全不可破解,那就安全了吗?当然不是,你要相信安全永远是相对的。试想一下如果App源码被反编译成功,那他就可以按照代码逻辑去拼出正常的请求?另外一般业务除了有app之外也会有使用相同接口的h5版,任意一个开发者通过浏览器的调试模式很容易能分析出请求的Url以及相关参数。对于这两种情况怎么办呢?
第二,对于可以获取数据的端,也可以控制其可以获取哪些数据
既然客户端不能做到完全可靠,那就让服务端多承担一些任务,在app启动时或者用户登录时服务端先向每个客户端分发一个有固定有效期的secret,并且在服务端数据库库中存储客户端唯一标示或者uid和secret的对应关系,之后每次客户端调用都要用secret对于参数组合进行一次签名,并且确保参数包含uid,服务端接收到请求后根据uid找出对应的secret,然后按照和客户端相同的签名方式得出签名,进而和客户端传过来的签名进行比较。
因为secret是服务端分发的,即使破解了源码,再即使从本地解析出了保存的secret,那也只能获取这个secret对应的数据,再加上secret本身会有更新机制,这就使得通过破解接口来抓取大量数据变得大大的困难。
但是对于向第三方开放的api接口情况就不太一样,它不存在密文传输的问题,大体思路也是使用secret进行签名认证,只是分发secret的方式不一样,它是通过合作的方式,api提供商会给使用方分发一个key和一个secret,两者可以当成一个键值对。调用方每次调用时用secret进行参数的签名,参数包含key,服务端接收到请求,根据key参数取出secret,然后进行相同方式的签名,并且和客户端传入的签名进行对比来完成验证。
总结一下数据保护的技术点:
参数传输使用密文,可以使用对称加密、非对称加密、或者两者的结合,比如https请求就是属于两者结合的方式。
app端要尽量加大反编译的难度,尽量保护源码安全。
通过参数id=>secret的方式进行签名来进行用户身份认证,调用方保存自己的secret,服务端保存id和secret的对应关系,secret用于签名,后续的每次请求都要带着id参数。
在第三步的基础上,加上timestamp参数来防止连接重复调用。
2. 安全性一些常用的安全问题都要考虑到,并且在api项目框架底层进行防范,例如xss攻击、sql注入问题、单用户或者单ip的访问频率控制来进行防cc攻击。
3. 旧版本兼容互联网产品版本迭代很快,对于同一个功能新旧版本在参数或者返回值上会有差别。对于这种问题会有不同观点的解决方案,一种方案是在url中加入版本信息,比如http://api.demo.com/v1/test , 每个版本对应一个Action,具体的业务逻辑不要写在Action层,要封装到下面的逻辑层,这样Action只需要在主业务的基础上根据需求进行扩展。另外一种观点是,这样代码重复度太高,会有大量的action文件,一个功能只提供一个唯一的url,但是要带上一个表示版本的参数,在代码框架中只有一个action,对于新旧版本的细小差别可以使用参数默认值等兼容方式进行处理,对于比较大的改动就通过逻辑判断语句进行不同处理即可。
另外比较重要的一点是,在设计之初要对业务进行足够的抽象化,让设计本身能尽量支持变化,比如以后此接口是否会增加某个分类属性,返回结果的格式是否再多包装一层就可以应对万一后面版本要增加另一块数据。
当然不可能同时维护所有旧的版本,要做到可以检测每个版本的使用情况,而且可以根据版本使客户端强制升级。对于功能的修改,同时维护旧版本是一件特别麻烦的事情,甚至有些情况不得不强制升级所有版本。
总结一下就是:
要能区分不同版本,通过url或者参数
设计时候尽量考虑之后扩展,足够抽象化
支持根据版本进行强制升级
4. 尽可能把所有业务逻辑都放到服务端很容易理解,服务端不用发版,服务端没有处理不了的问题,很简单一个例子:用户登录功能,会有"密码错误","还没有注册"等各种异常情况的提示。那具体的文案是在客户端定义,还是从服务端直接返回给客户端比较好呢,显然是后者。因为以后提示语内容要做修改的话,放在服务端就可以很简单进行处理,放在客户端只能重新发版。
5. 返回字段可定制,可帮用户节省流量A、B两个功能都需要获取用户信息,两者调用同一个接口,但是A只需要获取用户名和电话,就没有必要把其它信息返回给A。
6. 格式统一,易读uri统一化,不一定说非要用restful格式,但一定要有统一的规范。
响应结果格式也统一,建议在最外层节点至少包含:code,msg,result,response_time等字段,具体的业务功能数据封装在result中。
nginx公众号也会推送好文,主要聊聊后端技术,扫描或者搜索nginx即可添加。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/11355.html
摘要:是文档的一种表示结构。这些任务大部分都是基于它。这个实践的重点是把你在前端练级攻略第部分中学到的一些东西和结合起来。一旦你进入框架部分,你将更好地理解并使用它们。到目前为止,你一直在使用进行操作。它是在前端系统像今天这样复杂之前编写的。 本文是 前端练级攻略 第二部分,第一部分请看下面: 前端练级攻略(第一部分) 在第二部分,我们将重点学习 JavaScript 作为一种独立的语言,如...
摘要:组件监听自定义事件。组件触发自定义事件。生命周期钩子函数,后组件的所有的事件监听器会被移除。技术点总结组件设计的思想包括单数据流事件中心,核心是组件通信。完善给弹出日期面板和关闭日期面板增加组件自定义事件即调用触发和事件。预览 组件库官网 github地址 如果喜欢各位小哥哥小姐姐给个小星星鼓励一下哈, 请勿在生产环境中使用,供学习&交流~~ showImg(https://user...
摘要:导语本期采访对象黄允松,青云创始人及。作为一个纯粹的工具理性主义者,黄允松致力于打造优良的工具,大幅降低的复杂性,让一切变得更加平滑和简单,这是他让世界变得美好起来的方式。 showImg(http://segmentfault.com/img/bVbYfe);文:Gracia 摄影:周振邦(本文为原创内容,部分或全文转载均需经过作者授权,并保留完整的作者信息和技术人攻略介绍。) ...
摘要:第一部分介绍了如何使用和开发接口。由于系统变得越来越复杂,人们提出了称为预处理器和后处理器的工具来管理复杂性。当您第一次得知有预处理器和后处理器时,你很有可能在任何地方已经使用它们。我之前建议的文章,,也涵盖了预处理器相关的知识。 我记得我刚开始学习前端开发的时候。我看到了很多文章及资料,被学习的资料压得喘不过气来,甚至不知道从哪里开始。 本指南列出前端学习路线,并提供了平时收藏的一些...
阅读 2362·2021-11-11 16:54
阅读 2608·2021-09-26 09:47
阅读 3986·2021-09-08 09:36
阅读 2735·2021-07-25 21:37
阅读 931·2019-08-30 15:54
阅读 2542·2019-08-30 14:22
阅读 3252·2019-08-30 13:57
阅读 2576·2019-08-29 17:17