受到David Auerbach[1]的启发,我们分析了360通信录,发现了一些非常有趣的安全问题,这里我们谈谈它传输加密方面的问题。360通信录可以在奇虎的官方网站上下载[2]。这个应用提供了垃圾短信识别、来电号码识别等功能。下面是关于这个应用的一些基本信息。
App: 360 contact Version: 2.1.2 Package: com.qihoo360.contacts MD5: 024d2b182fcadf19dc31457e7612c297 SHA-1: de0c0d41dfae8d9803d898ba8955691dc7dffdf7
找备份的密钥
这个应用在设置选项中,还有一个备份的功能,使用这个功能,用户可以将通讯录备份到云上。我们先来看看用户备份时传输的数据:
从传输的数据我们可以看出,1、这个app使用了http协议来传输数据;2、传输数据被加密了。为了查清这个应用如何对数据进行加密,我们转向到这个app的代码。通过代码,我们发现,这个app使用了des加密算法来加密待传输的数据(Figure 2)。而加密密钥来自原生代码(Figure 3)。
接下来,我们转向原生代码,Figure 4是对应的,提供解密密钥的接口函数。其中的sub_758164B4()函数负责生成密钥。请注意,这个函数被调用时,携带的第二个参数是个常量。
随后,我们进入到函数sub_758164B4。分析发现,解密密钥来自于这个函数的第二个参数,其生成算法非常简单,即第二个参数所指向的字符串中的每个字符减13,就得到最后的解密密钥。前面我们提到,这个函数的第二个参数是个固定的字符串。
由此,我们得出,通过http协议传输的数据的解密密钥也是固定的,这个值为:*#13o-69!
解密数据
为了解密数据,我们又回到了java代码(Figure 8),通过分析,我们弄清楚了这段传输的数据(Figure 1)的具体含义:
接下来的工作应该来说就比较简单了,我们随后写了段简单的代码来验证了我们的结论。
参考
1.Auerbach, D. The encryption app NQ Mobile Vault uses laughably crackable encryption. It's not the only app that should make you nervous.; Available from: http://www.slate.com/articles/technology/bitwise/2015/04/nq_mobile_vault_the_popular_encryption_app_has_laughably_crackable_encryption.html.
2.qihu. 360 contact. Available from: http://txl.360.cn/.
* 墨贝科技(企业账号),转载须注明来自FreeBuf黑客与极客(FreeBuf.COM)