移动互联培训

您当前的位置:移动互联培训 > Android开发 >

Android数据传输安全

来源:Android开发学习网 2017-04-10

几天要为大家分享的是Android开发过程中的android 数据传输安全问题。

一 对敏感数据进行传输时应该采用基于SSL/TLS的HTTPS进行传输

由于移动软件大多只和固定的服务器通信,我们可以采用“证书锁定”(certificate pinning)方式在代码更精确地直接验证服务器是否拥有某张特定的证书。实现“证书锁定”的方法有二种:一种是实现X509TrustManager接口,另一种则是使用keystore。

二 登录验证和传输内容加密

1. 服务器接收到app发送的用户名和密码后,验证用户名和密码是否正确。

如果错误则返回错误信息。如果验证正确,生成一个随机的不重复的token字符串(例如"daf32da456hfdh"),在redis或memcache中维护一个映视表,建立token字符串和用户信息的对应关系表,例如,把token字符串"daf32da456hfdh"和用户id"5"对应起来。

2. 服务器把token字符串返回给app,app把这个token字符串保存起来,作为登录的验证。

3. 当需要验证用户身份的操作时,必须要把token字符串传给服务器验证身份。

例如,api "test.com/user/update"是更新用户的信息,必须要验证用户的身份.当调用api "test.com/user/update"时,把token字符串"daf32da456hfdh"放在url上,变成"test.com/user/update?token=daf32da456hfdh" .

当服务器接收到这个api请求,知道要验证用户身份的,于是,就把参数中token的值"daf32da456hfdh"取出来,在(1)中建立的token字符串和用户信息的对应关系表查找,如果发现没这个token值的,则返回验证失败的信息。如果发现有这个token值,则获取这个用户的信息,进行相关的更新操作。

4. 当用户退出登录时,需要通过调用api,让服务器把这个用户对于的token字符串删除.

例如,api "test.com/user/logout"是退出登录的api,也要验证用户身份, 则调用"test.com/user/logout?token=daf32da456hfdh" 。当服务器接到退出登录的api请求时,在(1)中建立的token字符串和用户信息的对应关系表查找token字符串,把token和用户信息都删除即可。

5. 加密登录和传输数据

整个过程如下:

用户名密码 + https + url签名(url+时间戳+随机字串)链接+请求时间+保唯一的字串

服务器返回token:aes(约定算法)=》(token+随机secret(就取上面那个签名中的16位))

app保存token后,以后每次机通信都通过 aes (token + 内容) 传输。

更多android 数据传输安全和其他Android开发技术文章,请持续关注我们。

400-611-6270

Copyright ©2004-2018 华清远见教育科技集团 版权所有
京ICP备16055225号,京公海网安备11010802025203号