前言
在app开放接口api的设计中,避免不了的就是安全性问题,由于大多数接口涉及到用户的我的信息以及一些敏感的数据,因此对这些接口须要进行身份的认证,html
那么这就须要用户提供一些信息,好比用户名密码等,可是为了安全起见让用户暴露的明文密码次数越少越好,咱们通常在web项目中,大多数采用保存的session中,python
而后在存一份到cookie中,来保持用户的回话有效性。可是在app提供的开放接口中,后端服务器在用户登陆后如何去验证和维护用户的登录有效性呢?web
回到目录后端
设计
对于敏感的api接口,需使用https协议api
https是在http超文本传输协议加入SSL层,它在网络间通讯是加密的,因此须要加密证书。https协议须要ca证书,通常须要交费。缓存
回到目录安全
一、原理
用户登陆后向服务器提供用户认证信息(如帐户和密码),服务器认证完后给客户端返回一个PID令牌,用户再次获取信息时,服务器
带上此令牌,若是令牌正取,则返回数据。对于获取Token信息后,访问用户相关接口,客户端请求的url须要带上以下参数:cookie
|
而后将全部用户请求的参数(包括timestamp,pid),而后更具MD5加密(能够加点盐),生成动态的url。
而后登录后每次调用用户信息时,带上timestamp,pid参数。
加上时间戳和pid后的URL:http://127.0.0.1:8888/index?pid=d073dae99f70b0cda2fa1ef8d25c527f|1475117419.5424652|0
就变成一个动态的并且相对的具备高安全的,保证数据安全的访问。
二、具体实现
1. api请求客户端想服务器端一次发送用用户认证信息(用户名和密码),服务器端请求到改请求后,验证用户信息是否正确。
若是正确:则返回一个惟一不重复的字符串,而后在Redis(任意缓存服务器)中维护这个用户信息关系,以便其余api对pid的校验。
若是错误:则返回错误码。
2.服务器设计一个url请求拦截规则
|
3.按期处理保存下来的动态请求URL
代码实现
服务端规定的规则
|
客户端按规则生成符合的
|
测试效果代码
|
这是比较粗超的API认证机制,能够初步了解。