今天介绍另外一种破解图案锁的方法。不过先要提醒大家,千万不要做坏事呦!
一、前提条件
手机需要root,而且打开调试模式。一般来讲,如果用过诸如“豌豆荚手机助手”、“360手机助手”一类的软件,都会被要求打开调试模式的。如果要删除手机内置软件,则需要将手机root。对于root有顾虑的童鞋,可以看看这篇文章《到底应该如何看待root这件事》
二、原理分析
首先科普一下,安卓手机是如何标记这9个点的。通过阅读安卓系统源码可知,每个点都有其对应的编号,组成了一个3×3的矩阵,形如:
00 01 02
03 04 05
06 07 08
假如设定解锁图形为一个“L”形,如图:
那么这几个点的排列顺序是这样的:00 03 06 07 08。系统就记下来了这一串数字,然后将这一串数字(以十六进制的方式)进行SHA1加密,存储在了手机里的/data/system/gesture.key 文件中。我们用数据线连接手机和电脑,然后ADB连接手机,将文件下载到电脑上(命令:adb pull /data/system/gesture.key gesture.key),如图:
用WinHex等十六进制编辑程序打开gesture.key,会发现文件内是SHA1加密过的字符串:c8c0b24a15dc8bbfd411427973574695230458f0,如图:
当你下次解锁的时候,系统就对比你画的图案,看对应的数字串是不是0003060708对应的加密结果。如果是,就解锁;不是就继续保持锁定。那么,如果穷举所有的数字串排列,会有多少呢?联想到高中的阶乘,如果用4个点做解锁图形的话,就是9x8x7x6=3024种可能性,那5个点就是15120,6个点的话60480,7个点181440,8个点362880,9个点362880。总共是985824种可能性(但这么计算并不严密,因为同一条直线上的点只能和他们相邻的点相连)。满打满算,也不到985824种可能性。乍一看很大,但在计算机面前,穷举出来这些东西用不了几秒钟。
三、破解过程
知道了原理,就着手写程序来实现吧。这里使用了Python来完成任务。主要应用了hashlib模块(对字符串进行SHA1加密)和itertools模块(Python内置,生成00-09的排列组合)。主要流程为:
1、ADB连接手机,获取gesture.key文件
2、读取key文件,存入字符串str_A
3、生成全部可能的数字串
4、对这些数字串进行加密,得到字符串str_B
5、将字符串str_A与str_B进行对比
6、如果字符串A,B相同,则说明数字串num就是想要的解锁顺序
7、打印出数字串num
下面为程序:
四、总结
从程序本身来说,得到解锁密码后应该用break跳出循环并终止程序运行。但Python并没有跳出多重循环的语句,如果要跳出多重循环,只能设置标志位然后不停进行判定。为了运行速度就略去了“跳出循环”这个步骤。(有没有更好的实现跳出多重循环的方法?)另外也略去了很多容错语句。
从破解目的来说,如果单单是忘记了自己的手机图形锁密码,完全可以用更简单的办法:ADB连接手机,然后“adb rm /data/system/gesture.key”删除掉gesture.key文件,此时图形锁就失效了,随意画一下就能解锁,在《忘记了手机锁怎么办》这篇文章中已经介绍过。
最后提一个安全小建议:如果手机已root,还要用“XX手机助手”,还想设置图形锁的话——在手机“设置”选项里,有一个“锁定状态下取消USB调试模式”(这个名字因手机而异,而且有的有此选项,有的手机就没有),开启此功能之后,在手机锁定状态下就能够防范此类攻击了。
推荐阅读:苹果7p是什么时候上市的
-
TFBOYS组合复工后更换头像!粉丝纷纷效仿
4月15日是一个奇妙的日子,是三个男孩子梦想开始的地方,从开始的《heart》到现在的《第一次告白》,他们一直在成长!就在今天,TFBOYS组合复工后在某社交平...
2020-04-16 -
魏大勋姐弟恋就差个官宣?乔振宇曾评价杨幂:喜
杨幂和魏大勋还差一点点就实锤了(差个官宣)。事情起因是最近有人拍到了魏大勋和杨幂共同进入酒店,助理买了三根冰淇淋,其中两根给了后座的魏大勋和一位女士。下车之后,...
2020-04-16 -
杨幂绯闻后首次发声,只提另一个男人?粉丝:失
要说最近的娱乐圈最大的瓜,莫过于杨幂与魏大勋的恋爱绯闻了。4月13日,有媒体爆出两人一起吃冰淇淋,出入酒店的照片;第二天又有爆料称杨幂乘车至魏大勋《涩女郎》片场...
2020-04-16 -
史无前例!卜凡约黑粉线下见面对方赴约,发文表
去年坤音娱乐ONER组合成员在举办完最后一场演唱会后分崩离析,卜凡因与公司单方面提出解约不被同意,之后与元公司陷入矛盾纠纷中,ONER四人组合就这样莫名其妙的解...
2020-04-16