binwalk
提取LZMA压缩数据,但无法识别提取的文件。 我在做什么错?
首先,我使用binwalk来获取一些细节,如下所示:
binwalk firmware.bin
输出: >
第二步:使用
dd
提取该lzma压缩数据。 DECIMAL HEXADECIMAL DESCRIPTION
----------------------------------------------------------------------
384272 0x5DD10 Base64 standard index table
428268 0x688EC Base64 standard index table
454224 0x6EE50 LZMA compressed data, properties: 0x6C, dictionary size: 33554432 bytes, uncompressed size: 3468924096053250820 bytes
输出:
dd if=firmware.bin bs=1 skip=454224 of=firmware.lzma
第三步:使用
lzma
获取数据45812+0 records in
45812+0 records out
45812 bytes (46 kB) copied, 0.245414 s, 187 kB/s
输出:
lzma -d firmware.lzma
为什么无法识别?我想念什么吗?
#1 楼
这是一个误报。二进制文件中没有LZMA压缩的数据。在没有固件二进制文件名的情况下不带任何参数运行
binwalk
等效于使用-B
或--signature
参数运行它,它指示binwalk
执行签名扫描。由于签名扫描本质上是在搜索特定的字节序列,因此误报会经常发生,尤其是对于短序列。因此,使用多种方法来控制误报的可能性,以验证binwalk
签名扫描的输出非常重要。这样的方法包括熵分析
可视化
检查二进制文件的十六进制转储
在二进制文件中搜索字符串
问题中由
binwalk
检测到的签名是LZMA压缩数据之一,这是一种压缩方法,整个文件专用于binwalk
的源代码。1。熵分析在确定
firmware.bin
中是否确实存在LZMA压缩部分时,使用最快和最容易的启发式方法是使用binwalk
进行熵扫描。 涉及压缩(以及其他形式的混淆处理,如打包,加密,编码等)时,通常有3种可能性:
整个二进制文件被压缩
二进制文件的某些区域被压缩
二进制文件不包含压缩
压缩导致压缩区域内的信息熵非常高。因此,通过在
binwalk
生成的熵图中查找熵级别接近1的区域,可以非常容易地发现压缩。请注意,在下面的示例中,术语“混淆”代替了“压缩”,因为通常仅使用熵分析就很难准确区分压缩,加密等。还要注意,在分析固件时,熵接近1是混淆的有力指标,而不是保证。这是因为固件二进制文件有时包含具有高熵的嵌入式图像文件,例如JPEG。诸如嵌入式图像文件之类的混杂因素降低了二进制文件中真正压缩(或混淆)的定位区域中熵扫描的准确性。
示例1:混淆了整个二进制文件
平坦的直线表示整个二进制文件的熵水平非常接近1,表明
示例2:二进制文件的某些区域被混淆了
在此固件二进制文件中,有2个混淆区域:一个从偏移量〜8000小数开始,到偏移量〜10000小数结束,另一个从偏移量35000扩展到EOF。
示例3:二进制文件不包含混淆
此图中的信息熵最大水平约为0.7,这与混淆不一致。 br />
firmware.bin
的熵图:熵分析输出:在
0x67400
处,熵水平出现一个峰值,接近1,但这与检测到LZMA压缩特征的偏移量在二进制文件中的位置不同,0x6EE50
:$ binwalk -E firmware.bin
DECIMAL HEXADECIMAL ENTROPY
--------------------------------------------------------------------------------
0 0x0 Falling entropy edge (0.204084)
54272 0xD400 Falling entropy edge (0.836558)
62464 0xF400 Falling entropy edge (0.828255)
124928 0x1E800 Falling entropy edge (0.825872)
130048 0x1FC00 Falling entropy edge (0.836094)
422912 0x67400 Rising entropy edge (0.991258) <---- spike
424960 0x67C00 Falling entropy edge (0.670723)
这使签名扫描输出的准确性令人怀疑。
2。可视化
可视化可用于非常快速地了解二进制文件的布局。熵图可以说是一种可视化类型:由于代码和数据具有不同的熵级别,因此可以使用熵图来了解二进制的布局。例如,文件头通常具有较低的熵,代码具有较高的熵,而ASCII数据在两者之间具有熵级别。
使用binvis.io可视化
firmware.bin
:注:蓝色是ASCII数据,粉色是接近1的熵。
<这些图像揭示了一些有趣的东西,这在熵图中并不明显:在ASCII数据集中的同一区域内,二进制文件中似乎存在混淆的数据块。下图放大了该区域:
该可能混淆的块位于图中熵尖峰的偏移量:
可以使用
hexdump
仔细检查这个特定区域。 3。 Ye Olde眼球+十六进制转储固件二进制文件可能很大,但通常只有某些部分会很有趣,值得直接检查。使用十六进制转储检查二进制区域还可以提供有关特定偏移量情况的某些信息。
对于
firmware.bin
,可能混淆的块及其周围的区域可以直接使用以下命令进行检查:hexdump -C -s 422000 -n 4096 firmware.bin | less
-s
参数跳过指定的字节数(十进制),这在处理大文件时特别有用。 /> 转储
0x67400
周围的区域:454224 0x6EE50 LZMA compressed data, properties: 0x6C, dictionary size: 33554432 bytes, uncompressed size: 3468924096053250820 bytes
看起来模糊的块始于偏移量
0x67314
而不是偏移量0x67400
。直接在混淆开始之前的ASCII字符串是C源文件crypto/src/wmcrypto_mem.c
的路径名,给定“ crypto”的引用,它指示加密功能。0x67C24附近的区域转储:
000672c0 00 00 00 00 00 00 63 6f 6e 6e 65 63 74 69 6e 67 |......connecting|
000672d0 20 74 6f 20 22 25 73 22 20 66 61 69 6c 65 64 20 | to "%s" failed |
000672e0 28 25 64 2f 25 64 29 00 45 72 72 6f 72 20 61 74 |(%d/%d).Error at|
000672f0 3a 20 25 73 2c 20 25 64 0a 00 63 72 79 70 74 6f |: %s, %d..crypto|
00067300 2f 73 72 63 2f 77 6d 63 72 79 70 74 6f 5f 6d 65 |/src/wmcrypto_me|
00067310 6d 2e 63 00 a5 63 63 c6 84 7c 7c f8 99 77 77 ee |m.c..cc..||..ww.| <- beginning of obfuscated block
00067320 8d 7b 7b f6 0d f2 f2 ff bd 6b 6b d6 b1 6f 6f de |.{{......kk..oo.|
00067330 54 c5 c5 91 50 30 30 60 03 01 01 02 a9 67 67 ce |T...P00`.....gg.|
00067340 7d 2b 2b 56 19 fe fe e7 62 d7 d7 b5 e6 ab ab 4d |}++V....b......M|
00067350 9a 76 76 ec 45 ca ca 8f 9d 82 82 1f 40 c9 c9 89 |.vv.E.......@...|
00067360 87 7d 7d fa 15 fa fa ef eb 59 59 b2 c9 47 47 8e |.}}......YY..GG.|
00067370 0b f0 f0 fb ec ad ad 41 67 d4 d4 b3 fd a2 a2 5f |.......Ag......_|
00067380 ea af af 45 bf 9c 9c 23 f7 a4 a4 53 96 72 72 e4 |...E...#...S.rr.|
00067390 5b c0 c0 9b c2 b7 b7 75 1c fd fd e1 ae 93 93 3d |[......u.......=|
000673a0 6a 26 26 4c 5a 36 36 6c 41 3f 3f 7e 02 f7 f7 f5 |j&&LZ66lA??~....|
000673b0 4f cc cc 83 5c 34 34 68 f4 a5 a5 51 34 e5 e5 d1 |O...h...Q4...|
000673c0 08 f1 f1 f9 93 71 71 e2 73 d8 d8 ab 53 31 31 62 |.....qq.s...S11b|
000673d0 3f 15 15 2a 0c 04 04 08 52 c7 c7 95 65 23 23 46 |?..*....R...e##F|
000673e0 5e c3 c3 9d 28 18 18 30 a1 96 96 37 0f 05 05 0a |^...(..0...7....|
000673f0 b5 9a 9a 2f 09 07 07 0e 36 12 12 24 9b 80 80 1b |.../....6..$....|
00067400 3d e2 e2 df 26 eb eb cd 69 27 27 4e cd b2 b2 7f |=...&...i''N....| <- offset of rising entropy edge
00067410 9f 75 75 ea 1b 09 09 12 9e 83 83 1d 74 2c 2c 58 |.uu.........t,,X|
00067420 2e 1a 1a 34 2d 1b 1b 36 b2 6e 6e dc ee 5a 5a b4 |...4-..6.nn..ZZ.|
00067430 fb a0 a0 5b f6 52 52 a4 4d 3b 3b 76 61 d6 d6 b7 |...[.RR.M;;va...|
00067440 ce b3 b3 7d 7b 29 29 52 3e e3 e3 dd 71 2f 2f 5e |...}{))R>...q//^|
00067450 97 84 84 13 f5 53 53 a6 68 d1 d1 b9 00 00 00 00 |.....SS.h.......|
00067460 2c ed ed c1 60 20 20 40 1f fc fc e3 c8 b1 b1 79 |,...` @.......y|
00067470 ed 5b 5b b6 be 6a 6a d4 46 cb cb 8d d9 be be 67 |.[[..jj.F......g|
00067480 4b 39 39 72 de 4a 4a 94 d4 4c 4c 98 e8 58 58 b0 |K99r.JJ..LL..XX.|
混淆区域末尾的ASCII字符串包括对WPA和EAPOL密钥的引用。
混淆块周围的字符串,包括
crypto/src/wmcrypto_mem.c
WPA: Sending EAPOL-Key 2/4
WPA: Invalid EAPOL-Key MIC when using TPTK - ignoring TPTK
WPA: RC4 failed
WPA: Unsupported AES-WRAP len %u
怀疑混淆的块与设备的加密有关
至于混淆块本身,它似乎由两部分组成:
第一部分包含许多对相同的字节,并且第二部分看起来很随机:
00067b80 b8 b3 45 06 d0 2c 1e 8f ca 3f 0f 02 c1 af bd 03 |..E..,...?......|
00067b90 01 13 8a 6b 3a 91 11 41 4f 67 dc ea 97 f2 cf ce |...k:..AOg......|
00067ba0 f0 b4 e6 73 96 ac 74 22 e7 ad 35 85 e2 f9 37 e8 |...s..t"..5...7.|
00067bb0 1c 75 df 6e 47 f1 1a 71 1d 29 c5 89 6f b7 62 0e |.u.nG..q.)..o.b.|
00067bc0 aa 18 be 1b fc 56 3e 4b c6 d2 79 20 9a db c0 fe |.....V>K..y ....|
00067bd0 78 cd 5a f4 1f dd a8 33 88 07 c7 31 b1 12 10 59 |x.Z....3...1...Y|
00067be0 27 80 ec 5f 60 51 7f a9 19 b5 4a 0d 2d e5 7a 9f |'.._`Q....J.-.z.|
00067bf0 93 c9 9c ef a0 e0 3b 4d ae 2a f5 b0 c8 eb bb 3c |......;M.*.....<|
00067c00 83 53 99 61 17 2b 04 7e ba 77 d6 26 e1 69 14 63 |.S.a.+.~.w.&.i.c|
00067c10 55 21 0c 7d 01 02 04 08 10 20 40 80 1b 36 00 00 |U!.}..... @..6..|
00067c20 80 00 00 00 0a 3e 3e 3e 3e 3e 3e 3e 3e 3e 3e 3e |.....>>>>>>>>>>>| <- end of obfuscated block
00067c30 3e 3e 3e 3e 3e 3e 0a 00 57 50 41 3a 20 53 65 6e |>>>>>>..WPA: Sen|
00067c40 64 69 6e 67 20 45 41 50 4f 4c 2d 4b 65 79 20 32 |ding EAPOL-Key 2|
00067c50 2f 34 0a 00 57 50 41 3a 20 53 65 6e 64 69 6e 67 |/4..WPA: Sending|
00067c60 20 45 41 50 4f 4c 2d 4b 65 79 20 34 2f 34 0a 00 | EAPOL-Key 4/4..|
00067c70 57 50 41 3a 20 49 6e 76 61 6c 69 64 20 45 41 50 |WPA: Invalid EAP|
00067c80 4f 4c 2d 4b 65 79 20 4d 49 43 20 77 68 65 6e 20 |OL-Key MIC when |
00067c90 75 73 69 6e 67 20 54 50 54 4b 20 2d 20 69 67 6e |using TPTK - ign|
00067ca0 6f 72 69 6e 67 20 54 50 54 4b 00 57 50 41 3a 20 |oring TPTK.WPA: |
00067cb0 49 6e 76 61 6c 69 64 20 45 41 50 4f 4c 2d 4b 65 |Invalid EAPOL-Ke|
00067cc0 79 20 4d 49 43 20 2d 20 64 72 6f 70 70 69 6e 67 |y MIC - dropping|
00067cd0 20 70 61 63 6b 65 74 00 57 50 41 3a 20 43 6f 75 | packet.WPA: Cou|
00067ce0 6c 64 20 6e 6f 74 20 76 65 72 69 66 79 20 45 41 |ld not verify EA|
00067cf0 50 4f 4c 2d 4b 65 79 20 4d 49 43 20 2d 20 64 72 |POL-Key MIC - dr|
检查偏移
0x6EE50
附近的二进制区域可能会揭示出为什么binwalk
错误地检测到LZMA压缩签名的原因:00067650 85 8a 8a 0f 90 70 70 e0 42 3e 3e 7c c4 b5 b5 71 |.....pp.B>>|...q|
00067660 aa 66 66 cc d8 48 48 90 05 03 03 06 01 f6 f6 f7 |.ff..HH.........|
00067670 12 0e 0e 1c a3 61 61 c2 5f 35 35 6a f9 57 57 ae |.....aa._55j.WW.|
00067680 d0 b9 b9 69 91 86 86 17 58 c1 c1 99 27 1d 1d 3a |...i....X...'..:|
00067690 b9 9e 9e 27 38 e1 e1 d9 13 f8 f8 eb b3 98 98 2b |...'8..........+|
000676a0 33 11 11 22 bb 69 69 d2 70 d9 d9 a9 89 8e 8e 07 |3..".ii.p.......|
000676b0 a7 94 94 33 b6 9b 9b 2d 22 1e 1e 3c 92 87 87 15 |...3...-"..<....|
000676c0 20 e9 e9 c9 49 ce ce 87 ff 55 55 aa 78 28 28 50 | ...I....UU.x((P|
000676d0 7a df df a5 8f 8c 8c 03 f8 a1 a1 59 80 89 89 09 |z..........Y....|
000676e0 17 0d 0d 1a da bf bf 65 31 e6 e6 d7 c6 42 42 84 |.......e1....BB.|
000676f0 b8 68 68 d0 c3 41 41 82 b0 99 99 29 77 2d 2d 5a |.hh..AA....)w--Z|
00067700 11 0f 0f 1e cb b0 b0 7b fc 54 54 a8 d6 bb bb 6d |.......{.TT....m|
00067710 3a 16 16 2c 50 a7 f4 51 53 65 41 7e c3 a4 17 1a |:..,P..QSeA~....| <- no more pairs after 0x67713
00067720 96 5e 27 3a cb 6b ab 3b f1 45 9d 1f ab 58 fa ac |.^':.k.;.E...X..|
00067730 93 03 e3 4b 55 fa 30 20 f6 6d 76 ad 91 76 cc 88 |...KU.0 .mv..v..|
00067740 25 4c 02 f5 fc d7 e5 4f d7 cb 2a c5 80 44 35 26 |%L.....O..*..D5&|
00067750 8f a3 62 b5 49 5a b1 de 67 1b ba 25 98 0e ea 45 |..b.IZ..g..%...E|
00067760 e1 c0 fe 5d 02 75 2f c3 12 f0 4c 81 a3 97 46 8d |...].u/...L...F.|
00067770 c6 f9 d3 6b e7 5f 8f 03 95 9c 92 15 eb 7a 6d bf |...k._.......zm.|
00067780 da 59 52 95 2d 83 be d4 d3 21 74 58 29 69 e0 49 |.YR.-....!tX)i.I|
00067790 44 c8 c9 8e 6a 89 c2 75 78 79 8e f4 6b 3e 58 99 |D...j..uxy..k>X.|
000677a0 dd 71 b9 27 b6 4f e1 be 17 ad 88 f0 66 ac 20 c9 |.q.'.O......f. .|
000677b0 b4 3a ce 7d 18 4a df 63 82 31 1a e5 60 33 51 97 |.:.}.J.c.1..`3Q.|
000677c0 45 7f 53 62 e0 77 64 b1 84 ae 6b bb 1c a0 81 fe |E.Sb.wd...k.....|
000677d0 94 2b 08 f9 58 68 48 70 19 fd 45 8f 87 6c de 94 |.+..XhHp..E..l..|
在检测到的LZMA压缩签名的偏移量之后,有很多空字节和重复字符。鉴于压缩区域具有较高的熵,这非常有力地表明检测到的签名是假阳性。
4。字符串
在二进制文件上运行
strings
实际上可以用作确定二进制文件是否被混淆的快速启发法。如果混淆了二进制文件,则strings -n 8 <binary>
的输出将如下所示:0006ee38 65 6c 2d 77 6c 61 6e 2d 78 78 78 00 02 04 0b 16 |el-wlan-xxx.....|
0006ee48 00 0c 12 18 24 30 48 60 6c 00 00 00 02 04 0b 0c |....}O.x|XsC
r@G8F2Qb
XL6%W(oO2
Ev]1m;[x
O[6.P&n>
)"VEg}6j
~uT/r]rJ
r5e?I+4[
UkzZT."DM
3ZJd{itt
Ba7=2X`N
[:}@8lW%
27 ]6cr0
/Ob4cNQBmg.4\)j
3F>go5pM
*0kJu|{@
:uB-c9Qq
YoO[p.1w
H`l.......| <- 0x6EE50
0006ee58 12 16 18 24 30 48 60 6c 00 00 00 00 0c 12 18 24 |...$ strings -n 8 firmware.bin | cat -n | tail
1966 marvel-wlan-xxx
1967 %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz
1968 &'()*56789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz
1969 !%/(!#,#
1970 )7),02454 '9=93=/342
1971 "22222222222222222222222222222222222222222222222222
1972 08/12/2013 12:08:32
1973 [mRFS-?]:
1974 gr&gr&b'
1975 nffffffff
H`l.......$|
0006ee68 b0 48 60 6c 00 00 00 00 00 00 00 00 00 00 00 00 |.H`l............|
0006ee78 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
*
0006eea8 00 00 00 00 03 00 00 00 14 00 00 00 0a 00 00 00 |................|
0006eeb8 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
*
0006f2b8 00 00 00 00 00 10 00 00 80 00 08 00 08 08 08 00 |................|
0006f2c8 04 41 10 00 84 10 42 00 22 22 22 00 12 91 48 00 |.A....B."""...H.|
0006f2d8 12 49 92 00 92 24 49 01 52 4a 4a 01 4a a5 4a 01 |.I...$I.RJJ.J.J.|
0006f2e8 aa 52 55 01 55 ad aa 00 b5 5a b5 00 ad b5 b5 00 |.RU.U....Z......|
混淆后的二进制文件将包含许多无意义的随机ASCII字符序列,很少或没有人类可读的字符串。
幸运的是,对于
firmware.bin
,由于二进制文件中的硬编码字符串数量很多,运行strings
会产生大量信息: .
.
.
application/src/garfield/md.c
application/src/garfield/taskq.c
application/src/garfield/ucos_api.c
application/src/garfield/utils.c
lwip-1.4.1/src/core/dhcp.c
lwip-1.4.1/src/core/dns.c
lwip-1.4.1/src/core/mem.c
lwip-1.4.1/src/core/memp.c
lwip-1.4.1/src/core/netif.c
lwip-1.4.1/src/core/pbuf.c
lwip-1.4.1/src/core/raw.c
lwip-1.4.1/src/core/tcp.c
lwip-1.4.1/src/core/tcp_in.c
lwip-1.4.1/src/core/tcp_out.c
lwip-1.4.1/src/core/timers.c
lwip-1.4.1/src/core/udp.c
lwip-1.4.1/src/core/ipv4/icmp.c
lwip-1.4.1/src/core/ipv4/ip.c
lwip-1.4.1/src/core/ipv4/ip_addr.c
lwip-1.4.1/src/core/ipv4/ip_frag.c
lwip-1.4.1/src/netif/etharp.c
lwip-1.4.1/src/netif/wlan_netif.c
lwip-1.4.1/src/api/api_lib.c
lwip-1.4.1/src/api/api_msg.c
lwip-1.4.1/src/api/netbuf.c
lwip-1.4.1/src/api/netdb.c
lwip-1.4.1/src/api/sockets.c
lwip-1.4.1/src/api/tcpip.c
crypto/src/wmcrypto_mem.c
libjfg/src/http.c
libjfg/src/msgpack_rpc.c
libjfg/src/ntp.c
libjfg/src/polling.c
libp2p/src/p2p.c
src/mrfs/mRfsDevice.c
src/mrfs/mRfsRetrieval.c
src/mrfs/mRfsSystem.c
.
.
.
路径名:
yun.jfgou.com
http://yun.jfgou.com:8080/package/camera/jiafeigou_2.3.0.8.bin
http://192.168.101.6:8000/ring.pcmu
jfg_debug: jfg_rtmp_connect(rtmp://10.0.1.19/live/sample)
硬编码的URL:
2.4.6.19
208.67.222.222
83.163.209.244
206.108.0.131
硬编码的IP地址
ucos start...
jfg_debug: ucos_sys_stat()
application/src/garfield/ucos_api.c
用户代理字符串:
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64)
内核:
camera sensor:PAS7366(8830),HW Version:V1!
camera sensor:PAS6375, HW Version:V2!
camera sensor:BF3006, HW Version:V3!
camera sensor:H7440H, HW Version:V4!
相机传感器零件编号:
jiafeigou
Jiafeigou Startup !!
Cylan-jfg-aes-password-prefix-%.*s%s
制造商名称
[0x00000000]> izz | grep wide
vaddr=0x00004918 paddr=0x00004918 ordinal=011 sz=76 len=37 section=unknown type=wide string=,%≄脾<"≄胼⅀Á⃠߁⍀Ã₨ƀᄁʄᬁĊ†߀ᄄȄᄄȅᬄĈߔ£ᬄň≄胼ᄄȄ߉
vaddr=0x00006e22 paddr=0x00006e22 ordinal=049 sz=14 len=6 section=unknown type=wide string=H\rᘐ᠐♀ᐁ
vaddr=0x000078a3 paddr=0x000078a3 ordinal=072 sz=18 len=8 section=unknown type=wide string=pÙ惚䩿쥳ѰÙϚ
vaddr=0x00009749 paddr=0x00009749 ordinal=155 sz=42 len=20 section=unknown type=wide string=yØ怜艸쨠쨇樠᐀ʸ谠輏ÿ怜【耠炏
vaddr=0x0000a980 paddr=0x0000a980 ordinal=199 sz=50 len=24 section=unknown type=wide string=P\t⚌郌⚌遌鮀䫴⚌逘⚌遘ኾༀ
vaddr=0x0000ae87 paddr=0x0000ae87 ordinal=216 sz=24 len=11 section=unknown type=wide string=\bÙ⋛耠脏鲛嫲Ò⋛耠脏
vaddr=0x0000b09b paddr=0x0000b09b ordinal=220 sz=16 len=7 section=unknown type=wide string=p@鸀䖺䋶ƺ興
vaddr=0x0000c6b1 paddr=0x0000c6b1 ordinal=314 sz=46 len=22 section=unknown type=wide string=xÙ耤ꠄ쀠⼁Ȥ삥ԡᬀ䁸耩ᨂb脡⨠횹䐟䈐䌢 ģ
vaddr=0x0000d5a8 paddr=0x0000d5a8 ordinal=351 sz=10 len=4 section=unknown type=wide string=@\vฏ玃
vaddr=0x0000dfcf paddr=0x0000dfcf ordinal=381 sz=20 len=9 section=unknown type=wide string=eà诚窺Ɫ貺켢쪏蘡
vaddr=0x0000fcf3 paddr=0x0000fcf3 ordinal=475 sz=28 len=13 section=unknown type=wide string=yØ怜荾쫠樠儀䃶Ȩ々耢ႏ
vaddr=0x0000fd1b paddr=0x0000fd1b ordinal=476 sz=28 len=13 section=unknown type=wide string=yØ怜荾쫠樠刀䃶Ȩ々耢ႏ
vaddr=0x0000fd45 paddr=0x0000fd45 ordinal=477 sz=30 len=14 section=unknown type=wide string=yØ怜荸쫠樠刀䃶Ȩ々耢ႏ
vaddr=0x0000fd71 paddr=0x0000fd71 ordinal=478 sz=30 len=14 section=unknown type=wide string=yØ怜荸쫠樠刀䃶Ȩ々耢ႏ
vaddr=0x0000fd9d paddr=0x0000fd9d ordinal=479 sz=16 len=7 section=unknown type=wide string=yØ怜ླྀ팈
vaddr=0x0000fe51 paddr=0x0000fe51 ordinal=480 sz=46 len=22 section=unknown type=wide string=yØ怜荸쫠樠倀䃶Ȩ々耢ႏⲙȀ谢푦⛿x“
vaddr=0x0000ff99 paddr=0x0000ff99 ordinal=482 sz=46 len=22 section=unknown type=wide string=yØ怜荸쫠樠倀䃶Ȩ々耢ႏ䲙Ȁ谢둦⛿x“
vaddr=0x000137d7 paddr=0x000137d7 ordinal=667 sz=18 len=8 section=unknown type=wide string=0Ø脡ƀ쀠ꠀ䀜갰
vaddr=0x00015062 paddr=0x00015062 ordinal=727 sz=28 len=13 section=unknown type=wide string=X\f蘥蜆牊砢蘦愙瀪煢•ྀ鮀
vaddr=0x00016e65 paddr=0x00016e65 ordinal=843 sz=10 len=4 section=unknown type=wide string=\a!䈄什
vaddr=0x000170d3 paddr=0x000170d3 ordinal=851 sz=20 len=9 section=unknown type=wide string="#䄧줔≲耠耏킛丈
vaddr=0x0001c948 paddr=0x0001c948 ordinal=1244 sz=76 len=37 section=unknown type=wide string=,%≄脾<"≄胼⅀Á⃠߁⍀Ã₨ƀᄁʄᬁĊ†߀ᄄȄᄄȅᬄĈߔ£ᬄň≄胼ᄄȄ߉
vaddr=0x0001c9c5 paddr=0x0001c9c5 ordinal=1246 sz=106 len=52 section=unknown type=wide string=sÁ䃚ꆩ퇀ˀ耏ꇅ䃁࿀⣐䑲藁ໃ怏謀qÁꃝ⒩믜态ꄂ㫀䀉ࠂ䡶婢ﵰeØ覭态ꀂﱸ膉ዀ䀉
.
.
.
vaddr=0x000240d1 paddr=0x000240d1 ordinal=1668 sz=12 len=5 section=unknown type=wide string=rÙ⊅耠舏
vaddr=0x00024e4b paddr=0x00024e4b ordinal=1801 sz=10 len=4 section=unknown type=wide string= Á䀘ꄠ
vaddr=0x00027841 paddr=0x00027841 ordinal=1914 sz=36 len=17 section=unknown type=wide string=x!ȡ 脢/㠀耏쫡愠!耀쳢∠
vaddr=0x00027f90 paddr=0x00027f90 ordinal=1933 sz=38 len=18 section=unknown type=wide string=n§¾ùª阜Dz,瞺睚♀Ἅ⪄☃甧ᕀႃ
vaddr=0x0002c3b9 paddr=0x0002c3b9 ordinal=2352 sz=72 len=35 section=unknown type=wide string=\aØƭƍǠ₍耠脏鲛큸蚘㲛薁䢛苼棅ﳘÙ⋚耠耏ﵪ࿙桽Ø⋚耠耏鑪
vaddr=0x0002eb5d paddr=0x0002eb5d ordinal=2488 sz=48 len=23 section=unknown type=wide string=!!ⱳƈⳡᆨÐ⊀耠舏풛꼪Ž췥舍膓지≱耠舏璛᪓p
vaddr=0x0002fc3c paddr=0x0002fc3c ordinal=2528 sz=10 len=4 section=unknown type=wide string=0%瘨팑
vaddr=0x00032899 paddr=0x00032899 ordinal=2640 sz=38 len=18 section=unknown type=wide string=x¦ᶇꁥƧ⃘耠脏鲛ꇓ⋀耠脏㢛⣓䡶䁵
vaddr=0x000341cd paddr=0x000341cd ordinal=2726 sz=12 len=5 section=unknown type=wide string=q©Ɔà憦
vaddr=0x000341ef paddr=0x000341ef ordinal=2727 sz=42 len=20 section=unknown type=wide string=q©Ɔà¦䏘ೀ⃰Ɔ൩Ԉ〄苘q©憆ƽà匍
vaddr=0x0003422b paddr=0x0003422b ordinal=2728 sz=64 len=31 section=unknown type=wide string=q©Ɔàᮦ諰쥰≲耠萏쒛፳⃰Ɔᝩ┈䈄刢 耤⠴쀐舀q©Ɔàʦ旀匈
vaddr=0x0003427d paddr=0x0003427d ordinal=2729 sz=10 len=4 section=unknown type=wide string=q©Ɔà
vaddr=0x00034293 paddr=0x00034293 ordinal=2730 sz=110 len=54 section=unknown type=wide string=q©䊆嘦Ġà匎㦠䌏—Ɔᕩ┈䈄儡 䀤吴쀐舀q©Ɔàꏱ刊䪠Ͱ⋙耠脏ﲛ짓꿩◱刍†Ɔᕩ┈䈄唥 䀤耵쀐舀q©Ɔà
vaddr=0x0003430f paddr=0x0003430f ordinal=2731 sz=48 len=23 section=unknown type=wide string=q©ƆàƦ胱Ȥ‱耠脏䲛⋀耠脏ႛꯓ嫁⡰究ᩲ衳
vaddr=0x000345d3 paddr=0x000345d3 ordinal=2741 sz=50 len=24 section=unknown type=wide string=rªƁǥàልₐ耠脏鲛䩸虎螛䄠ࠅ葱ġ䄌ĩ厁술Ѐ
vaddr=0x00035493 paddr=0x00035493 ordinal=2778 sz=38 len=18 section=unknown type=wide string=1Ø䃙숧ਗ$∄耠茏袛ග⇱ÒØ⋙耠茏袛
vaddr=0x00037c3e paddr=0x00037c3e ordinal=2958 sz=10 len=4 section=unknown type=wide string=0,眈팷
vaddr=0x0003812c paddr=0x0003812c ordinal=2973 sz=10 len=4 section=unknown type=wide string=6\t₌胄
vaddr=0x000382a8 paddr=0x000382a8 ordinal=2978 sz=10 len=4 section=unknown type=wide string=2\t₌脄
vaddr=0x0003ab89 paddr=0x0003ab89 ordinal=3169 sz=10 len=4 section=unknown type=wide string= Ø蘐䐠
vaddr=0x0003e2f9 paddr=0x0003e2f9 ordinal=3426 sz=22 len=10 section=unknown type=wide string=\aØ⋙耠蔏鲛Ⰺ᧰Ò惘
vaddr=0x0003f6b3 paddr=0x0003f6b3 ordinal=3514 sz=134 len=66 section=unknown type=wide string=p\e䀠ᐣ琦⋕耠茏璛瓶䃖ᄠᐄဒ⠠ᜒꤠⁱᘒ訠聰䌡꤀恲聾䈢ࠏ艷ꥰ聱䌡꤀恲聾䌢ἁg'ꤕ聱䌡꤀恲聾䌢ἁg'ꤕ聱茡ꨁ恲聾ढ艠ꥰ聱茡嘂舡ਪੳ쀤怅
由于制造商是中国公司,因此使用radare2搜索unicode字符序列可能会发现潜在的相关信息,而这些信息可能不会在常规十六进制转储中显示:或可能不是有意义的信息。我不知道。
结论
所有这些的要点是表明基于签名的扫描倾向于产生假阳性并且也不能完全检测出假阳性。固件二进制文件中包含一些有趣的信息(假设它们没有被混淆),并且这些工具不能代替大脑。即使扫描完全不输出,使用其他方法仍可能会找到有用的信息。有几种工具和技术可用于提取有趣或有用的信息,并且不应过度依赖单个工具或方法或隐式信任工具的输出。
binwalk
版本,看它是否为最新版本。缺少LZMA压缩签名):$ md5sum firmware.bin
5b36cb0905c92a746dc561b03eed570e firmware.bin
评论
一个非常彻底的答案! +1!我正在使用同一台相机玩,所以这会很有帮助!
–劳伦斯
17 Dec 9'在5:11
@劳伦斯非常感谢和祝你好运
– julian♦
17年12月9日在6:58
@Lawrence:请分享您的研究成果:)
–v1h5
18年1月30日在5:41
@SYS_V:+1奇妙的解释。
–v1h5
18年1月30日在5:42
评论
这可能是假阳性,字典的大小大于提取的数据,而未压缩的数据看起来根本很疯狂。接下来是什么 ??还有其他选择吗?
binwalk -v firmware.bin说什么?
签名:374十六进制说明-------------------------------------------- ------------------------------------ 384272 0x5DD10 Base64标准索引表428268 0x688EC Base64标准索引表454224 0x6EE50 LZMA压缩数据,属性:0x6C,字典大小:33554432字节,未压缩大小:3468924096053250820字节
搞砸了意图。顺便说一句,它与binwalk firmware.bin相同,仅包含MD5校验和,扫描时间和我机器中的firmware.bin路径的其他详细信息