$ k1 ?5 M& ]. J6 B s1 s4 y 在中世纪的绘画作品中,偶尔会出现一种盛放金银珠宝的木制橱柜,这被认为是现代保险柜的雏形。整个十九世纪,欧洲与美国一直致力于保险柜的研发以及防火性、安全性(保险柜用锁具)的提升。到二十世纪六七十年代,电子密码锁开始广泛应用于不同类型的保险柜。随着科技的发展,如今不少保险柜也与时俱进,接入了互联网,以期实现远程控制、联网报警等功能,让保险柜更“保险”。但这意味着100%的安全吗?
. ^: X6 f3 ~ K7 W! [8 k# Q) S( i' _# u2 q S0 n1 y
《我是极客》第一集第一组挑战项目的选手,在舞台上给出了答案:利用部分联网的保险箱存在的安全问题,不用破解密码,几分钟就能打开这些保险箱。现场的挑战一度让嘉宾惊呼“鸡皮疙瘩都起来了。”此外,他们还现场拆解智能硬盘并破解、获取了其中的加密信息。挑战突破物理、数字的双重防御。
) u, k9 c; z {
# @3 R' b7 x' f- x6 m/ c9 x: W! M9 b 在“1024极棒之夜现场”,这个项目的选手分享了研究过程中的一些心得与经验。本文为现场实录(摘要),供读者参考。
5 b8 ^$ w5 p+ {# z
2 B- _. G' {/ B% W, Q H0 }
; v* c6 e. U' L1 `! I( X *文末附《破防了》项目技术分享视频9 A% h7 Y- m# s+ d- k$ Z
6 q) l' f# `2 s) q% H0 S' ]: H# F9 s/ ^
日拱一卒 功不唐捐
4 P5 f: H/ m# i+ S, y. h8 S; E# P2 `2 @& y- s/ t. o2 Z: z
9 A1 W8 Z; f8 [$ k( U3 T
* ^2 @/ Y2 X9 q6 Q 因为团队专注于芯片底层安全研究,在研究 ESP8266 芯片时,发现其广泛使用的一个 SDK 通信协议的 AES256 加密算法存在漏洞。因此灵光一现,想到利用这个漏洞无损破解应用这款芯片方案的智能保险柜。
$ ~) ^3 [ G5 r- t; P7 Q; R+ M: m" i `9 [ c
% w0 X& p/ ^9 b! e' b- l/ L 市面上有很多销量比较高且应用这款芯片方案的智能保险柜。当合理的开锁请求发到与保险柜连接的手机上后,就可以远程打开保险柜。比赛中挑战的保险柜号称采用的是银行密钥管理系统,在行业内具有一定的代表性。" M) {5 q1 S% y# u' ^( h
8 l. k1 M6 T9 _: l6 |0 x
: \( Q7 T" z& P& I: X+ S
发现SDK加密协议漏洞之后,我们又分析了智能保险柜的通信协议,然后劫持保险柜的网络,伪造了一个服务器。当保险柜发开锁的请求给服务器的时候,我们可以把请求给拦截下来,然后伪造一个开门的数据下发给保险柜,然后就可以成功开门。
i' d6 X! ]3 O2 O& [! O: y
破解加密硬盘. P' k+ H. [1 m1 L. Q. s; F
( K( S; n( l& H. }1 x" s6 b9 N
% T2 T+ A8 E. }% D 延续破解保险柜的思路,我们还研究破解了大量智能硬盘。这次的挑战目标也是一款较有代表性的产品——利用生物独特性,打造支付级高精密指纹识别技术的智能加密硬盘。保险柜如果算作物理防御,硬盘就是数字防御。' y, u$ Z" D# X; x' N9 H) z
8 o! H% P+ y0 P
$ X- T7 m$ r+ V [2 U; P
$ }3 ^: Y0 p6 _2 v+ `/ c( V 在实际操作中,先把硬盘主控的固件提取出来,去分析它的解密算法。然后用侧信道把指纹模块上面的固件也提取出来,分析协议就可以得到指纹模块的ID。因为这类硬盘的验证先会请求指纹的ID,如果ID不匹配,就不会正常启动硬盘。所以要先把硬盘拆开拿到ID,然后伪造这个ID发给硬盘。待硬盘验证这个ID为正确之后,就会建立连接。下一步就是伪造指纹的数据发给硬盘,让硬盘的主控校验这个数据。如果验证认为指纹数据正确,电脑上就会出现一个盘符,里面就是加密后的数据了。% R9 v5 |3 Q4 A
1 N8 k2 A" T/ z! S6 N# `
在极棒之夜上,除了分享项目技术细节并再次展示破解保险柜的过程。这个史上队名最长的团队还分享了一枚彩蛋,与这两天不退押金反而套路用户的ofo有关。具体是什么,直接戳视频观看。( K$ r! E: ]8 q, y) E* X' l
2 z. Q. m* T/ [
7 i6 H+ v- S9 b! E+ z$ F( k
; M- [. M a" ?( J4 X0 k& T) R
欢迎光临 中华锁艺人 (https://suoyiren.com/) | Powered by Discuz! X3.5 |