做为后端程序猿本身写的接口
就像本身的孩子
同样,尽然制造出来了,那就要对他之后的人生负责到底;
随着业务的壮大,须要支撑业务接口也愈来愈多,使用的用户量变大,虎视眈眈的黑客们视机而动,老是在业务中寻找着能够窃取他人利益的入口,因此咱们应该多考虑安全性问题,防范于未然。前端
服务端程序猿根据需求开发出业务相关的接口,用来知足需求中用户和服务器交互的功能,提供给前端或者客户端(PC端软件,APP端应用)使用, 大部分程序猿在开发接口的时候就仅仅去考虑如何实现业务上的逻辑功能,而每每不多会去考虑接口的安全性问题, 通常服务端提供的接口都是http/https协议的,经过Fiddler,Wireshark,Charles等抓包工具,能够抓取到请求,而后进行分析,模拟请求,进行并发请求,或者修改信息的攻击。程序员
描述:程序猿在作业务接口的时候每每没有保护用户隐私的意识,把用户的隐私信息暴露在外面,一旦被人利用起来会给用户带来麻烦,同时被发现会下降平台的信任度;数据库
用户参与活动的数据JSON集合中不要有活动相关业务逻辑的决定性的数据,如:竞拍出价活动,出价惟一最低者拿奖品,结果获取出价的接口暴露了全部出价的价格统计结果。后端
描述:接口中的JSON数据会被其余人拿去作本身的相关的功能;这样就形成了服务器的额外支出安全
描述:经过修改请求中的参数来发起的请求,如:登录接口修改用户名和用户密码,进行密码库碰撞等。服务器
舒适提示:
修改请求参数可能会致使不少安全性问题,如:SQL注入,XSS 跨站脚本攻击等,传送门个人【大话程序猿眼里的WEB安全】有相关的介绍和解决方案
如下方案都针对客户端,如PC软件和APP,WEB端JS去作加密的话不是很推荐,JS代码是暴露出来的,因此若是用JS作加密必定要混淆JS代码并发
增长一个签名参数,将参数名进行逻辑的排序组合拼接+秘钥MD5,而后服务端接受到请求的时候也用一样的逻辑获得签名与签名参数进行对比是否相同,这样可使参数没法被修改,修改了就提示非法请求。 如: 接口http://www.test.com/go/?actid=1&userid=123 咱们能够加一个sign参数= MD5(actid=1&userid=123&【secret】)【secret】=秘钥,本身定义。 服务端用同样的逻辑获得密文和sign签名进行对比是否同样,不同就提示非法请求。高并发
描述:经过抓包工具抓到请求后模拟请求,如:模拟每日签到请求,或者直接发起每日签到的并发请求。
舒适提示:当请求并发后如何保证数据的完整性,一致性问题,这也是平时开发很须要注意的问题,传送门个人【大话程序员眼里的高并发】有相关的介绍和解决方案。工具
咱们须要提升本身的安全意识,防范于未然,要多站在攻击者的角度来看本身的接口;(让本身有一种被害妄想症的感受,你就离精神病近了一步,<( ̄︶ ̄)↗ ) 不要作开发需求的机器人,咱们是有思想有创造力的开发者;性能
在评审需求的时候要把业务逻辑问题提出来,并给予解决方案的选择; 肯定需求后将整个业务逻辑的梳理清楚,复杂的能够画出流程图; 根据需求设计实现方案,须要考虑性能问题[数据库压力,服务器压力],安全问题,用文档的形式记录下本身的设计方案。(能够深刻到代码层面如何去实现); 列出需求中功能点,评估出本身的时间,获得总工时; 开始开发,开干;