涨姿势了!如何破解Android手机的图形锁

安卓手机的图形锁(九宫格)是3×3的点阵,按次序连接数个点从而达到锁定/解锁的功能。最少需要连接4个点,最多能连接9个点。网上也有暴力删除手机图形锁的方法,即直接干掉图形锁功能。但假如你想进入别人的手机,但又不想引起其警觉的话……你可以参考一下本文。

涨姿势了!如何破解Android手机的图形锁的照片 - 1

前提条件:手机需要root,而且打开调试模式。一般来讲,如果用过诸如“豌豆荚手机助手”、“360手机助手”一类的软件,都会被要求打开调试模式的。如果要删除手机内置软件,则需要将手机root。

原理分析

首先科普一下,安卓手机是如何标记这9个点的。通过阅读安卓系统源码可知,每个点都有其编号,组成了一个3×3的矩阵,形如:

00 01 02
03 04 05
06 07 08

假如设定解锁图形为一个“L”形,如图:

涨姿势了!如何破解Android手机的图形锁的照片 - 2

那么这几个点的排列顺序是这样的:00 03 06 07 08。系统就记下来了这一串数字,然后将这一串数字(以十六进制的方式)进行SHA1加密,存储在了手机里的/data/system/gesture.key 文件中。我们用数据线连接手机和电脑,然后ADB连接手机,将文件下载到电脑上(命令:adb pull /data/system/gesture.key gesture.key),如图:

涨姿势了!如何破解Android手机的图形锁的照片 - 3

用WinHex等十六进制编辑程序打开gesture.key,会发现文件内是SHA1加密过的字符串:c8c0b24a15dc8bbfd411427973574695230458f0,如图:

涨姿势了!如何破解Android手机的图形锁的照片 - 4

当你下次解锁的时候,系统就对比你画的图案,看对应的数字串是不是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

下面为程序

涨姿势了!如何破解Android手机的图形锁的照片 - 5

总结

从程序本身来说,得到解锁密码后应该用break跳出循环并终止程序运行。但Python并没有跳出多重循环的语句,如果要跳出多重循环,只能设置标志位然后不停进行判定。为了运行速度就略去了“跳出循环”这个步骤。(有没有更好的实现跳出多重循环的方法?)另外也略去了很多容错语句。

从破解目的来说,如果单单是忘记了自己的手机图形锁密码,完全可以用更简单的办法:ADB连接手机,然后“adb rm /data/system/gesture.key”删除掉gesture.key文件,此时图形锁就失效了,随意画一下就能解锁。但本文开篇假设的是“为了不被察觉地进入到别人的手机里”,所以就有了这篇文章。

最后提一个安全小建议:如果手机已root,还要用“XX手机助手”,还想设置图形锁的话——在手机“设置”选项里,有一个“锁定状态下取消USB调试模式”(这个名字因手机而异,而且有的有此选项,有的手机就没有),开启此功能之后,在手机锁定状态下就能够防范此类攻击了。此文技术原理很简单,还望各位大大传授些高大上的Python编程技巧。

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:9   其中:访客  9   博主  0

  1. 秋意盎然 5
    Internet Explorer 11.0 Internet Explorer 11.0 Windows 8.1 x64 Edition Windows 8.1 x64 Edition

    有点小复杂,不过如果真能成功那也是不错的。

    江苏省徐州市 电信
  2. 純潶冷眸 5
    Internet Explorer 11.0 Internet Explorer 11.0 Windows 7 Windows 7

    这事需要实践,如果自己成功,帮助不小啊。

    河南省南阳市邓州市 电信
  3. >3<知足$_$ 5
    Internet Explorer 11.0 Internet Explorer 11.0 Windows 8.1 x64 Edition Windows 8.1 x64 Edition

    这个方法安卓解锁秒杀了

    福建省厦门市 电信
  4. 坏人阿阳 5
    Google Chrome 41.0.2272.76 Google Chrome 41.0.2272.76 Windows 8.1 x64 Edition Windows 8.1 x64 Edition

    好复杂……

    内蒙古包头市 联通
  5. 真爱8023永恒 5
    uBrowser 4.0.4253.0 uBrowser 4.0.4253.0 Windows 8.1 x64 Edition Windows 8.1 x64 Edition

    这个不错,仅仅暴力解决锁屏,有前提适用范围小,进入rec直接双清。这个更加简单粗暴

    广西南宁市 联通
  6. wylgogogo 5
    Google Chrome 26.0.1410.43 Google Chrome 26.0.1410.43 Windows 7 x64 Edition Windows 7 x64 Edition

    怎么感觉破解比windows麻烦多了。

    湖南省衡阳市 电信
  7. 天使の守護者 5
    Google Chrome 41.0.2272.74 Google Chrome 41.0.2272.74 Windows 8.1 x64 Edition Windows 8.1 x64 Edition

    厉害! 安卓的密码原来如此脆弱.可惜不会编程.

    山东省烟台市 联通
  8. ╰MI恋ゝ黑曜色の阳光ミ 5
    Google Chrome 31.0.1650.63 Google Chrome 31.0.1650.63 Windows 8.1 x64 Edition Windows 8.1 x64 Edition

    还是删掉比较简单暴力。穷举法太麻烦

    山东省济南市 联通
  9. ice顽石 1
    Firefox 38.0 Firefox 38.0 Windows 10 x64 Edition Windows 10 x64 Edition

    很不错的,菜鸟来学习中。。。。。

    四川省广安市 移动