首页
社区
课程
招聘
对360通信录加密方式的技术分析
发表于: 2015-6-25 09:38 1056

对360通信录加密方式的技术分析

2015-6-25 09:38
1056
新闻链接:http://www.freebuf.com/articles/terminal/70802.html
新闻时间:2015-06-25
新闻正文:受到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/.

[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

收藏
免费 0
支持
分享
最新回复 (0)
游客
登录 | 注册 方可回帖
返回
//