14351463033448

受到David Auerbach[1]的启发,我们分析了360通信录,发现了一些非常有趣的安全问题,这里我们谈谈它传输加密方面的问题。360通信录可以在奇虎的官方网站上下载[2]。这个应用提供了垃圾短信识别、来电号码识别等功能。下面是关于这个应用的一些基本信息。

App: 360 contact
Version: 2.1.2
Package: com.qihoo360.contacts
MD5: 024d2b182fcadf19dc31457e7612c297
SHA-1: de0c0d41dfae8d9803d898ba8955691dc7dffdf7

找备份的密钥

这个应用在设置选项中,还有一个备份的功能,使用这个功能,用户可以将通讯录备份到云上。我们先来看看用户备份时传输的数据:

14351463033448

从传输的数据我们可以看出,1、这个app使用了http协议来传输数据;2、传输数据被加密了。为了查清这个应用如何对数据进行加密,我们转向到这个app的代码。通过代码,我们发现,这个app使用了des加密算法来加密待传输的数据(Figure 2)。而加密密钥来自原生代码(Figure 3)。

14351463033448

14351463033448

接下来,我们转向原生代码,Figure 4是对应的,提供解密密钥的接口函数。其中的sub_758164B4()函数负责生成密钥。请注意,这个函数被调用时,携带的第二个参数是个常量。

14351463033448

随后,我们进入到函数sub_758164B4。分析发现,解密密钥来自于这个函数的第二个参数,其生成算法非常简单,即第二个参数所指向的字符串中的每个字符减13,就得到最后的解密密钥。前面我们提到,这个函数的第二个参数是个固定的字符串。

由此,我们得出,通过http协议传输的数据的解密密钥也是固定的,这个值为:*#13o-69!

14351463033448

14351463033448

解密数据

为了解密数据,我们又回到了java代码(Figure 8),通过分析,我们弄清楚了这段传输的数据(Figure 1)的具体含义:

14351463033448

14351463033448

接下来的工作应该来说就比较简单了,我们随后写了段简单的代码来验证了我们的结论。

14351463033448