{"id":456,"date":"2016-01-06T18:25:24","date_gmt":"2016-01-06T10:25:24","guid":{"rendered":"http:\/\/blog.md5.red\/?p=456"},"modified":"2016-01-22T12:20:56","modified_gmt":"2016-01-22T04:20:56","slug":"android%e9%94%81%e5%b1%8f%e5%af%86%e7%a0%81%e7%a0%b4%e8%a7%a3-%e5%a4%87%e5%bf%98","status":"publish","type":"post","link":"https:\/\/blog.md5.red\/?p=456","title":{"rendered":"Android\u9501\u5c4f\u5bc6\u7801\u7834\u89e3\u7814\u7a76\u3010\u4e5d\u5bab\u683c\u548c\u590d\u6742\u5bc6\u7801\u3011"},"content":{"rendered":"<h3>\u4e5d\u5bab\u683c\u5bc6\u7801<\/h3>\n<p>\u5bc6\u6587\u5b58\u50a8\u4e8e\uff1a\/data\/system\/gesture.key \u3002\u4f7f\u7528sha1\u52a0\u5bc6\uff0c\u5bf9\u5e94\u4f4d\u7f6e\u8868\u793a\u7684\u6570\u5b57\u5982\u4e0b\uff1a<\/p>\n<p><a href=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/13967864366300.jpg\" class=\"highslide-image\" onclick=\"return hs.expand(this);\" rel=\"attachment wp-att-457\"><img decoding=\"async\" class=\"alignnone size-medium wp-image-457\" src=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/13967864366300-300x292.jpg\" alt=\"13967864366300\" width=\"300\" height=\"292\" srcset=\"https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/13967864366300-300x292.jpg 300w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/13967864366300.jpg 548w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\u6ce8\u610f\u662f\u5341\u516d\u8fdb\u5236\u3002<\/p>\n<p>\u6bd4\u5982\u6700\u5de6\u4fa7\u6700\u4e0b\u4fa7\u5212\u4e00\u7ad6\u4e00\u6a2a\u5c31\u662f\u201c0003060708\u201d\uff0c\u5bf9\u5e94\u5bc6\u6587\u662f\u201cc8c0b24a15dc8bbfd411427973574695230458f0\u201d<\/p>\n<p><a href=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/gesture.jpg\" class=\"highslide-image\" onclick=\"return hs.expand(this);\" rel=\"attachment wp-att-484\"><img decoding=\"async\" class=\"alignnone size-full wp-image-484\" src=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/gesture.jpg\" alt=\"gesture\" width=\"638\" height=\"94\" srcset=\"https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/gesture.jpg 638w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/gesture-300x44.jpg 300w\" sizes=\"(max-width: 638px) 100vw, 638px\" \/><\/a><\/p>\n<p>python\u4ee3\u7801\uff1a<\/p>\n<p>import hashlib<br \/>\na = '\\x00\\x03\\x06\\x07\\x08'<br \/>\nprint 'sha1 = %s' % (hashlib.sha1(a).hexdigest(),)<\/p>\n<p>\u6837\u672c\u5bb9\u91cf\u5f88\u5c0f\uff0c\u53ef\u4ee5\u66b4\u529b\u7834\u89e3\uff0c\u4e5f\u53ef\u4ee5\u751f\u6210\u4e2a\u5b57\u5178\u67e5\u8be2\u3002<\/p>\n<p>\u611f\u8c22<span class=\"name\"><a title=\"\u7531 \u4e09\u53ea\u5c0f\u6f74 \u53d1\u5e03\" href=\"http:\/\/www.freebuf.com\/author\/%e4%b8%89%e5%8f%aa%e5%b0%8f%e6%bd%b4\" rel=\"author\">\u4e09\u53ea\u5c0f\u6f74<\/a>\uff0c\u5df2\u7ecf\u505a\u597d\u4e86\u5b57\u5178\u548c\u67e5\u8be2\u4ee3\u7801\u3002<\/span><\/p>\n<p><span class=\"name\">\u6211\u4e0a\u4f20\u5230\u670d\u52a1\u5668\u4e86\uff0c\u5927\u5bb6\u53ef\u4ee5\u4e0a\u4f20gesture.key\u7834\u89e3\u6d4b\u8bd5\u3002<\/span><\/p>\n<div class=\"content\">\n<form action=\"http:\/\/blog.md5.red\/wp-content\/uploads\/AndroidCrack\/crack.php\" enctype=\"multipart\/form-data\" method=\"post\" target=\"_blank\"><input name=\"file\" type=\"file\" \/><input name=\"submit\" type=\"submit\" value=\"Submit\" \/><\/p>\n<p>(imagettftext()\u51fd\u6570\u5728Linux\u4e0a\u7adf\u7136\u4e0d\u80fd\u4f7f\u7528simkai.ttf\u5b57\u4f53\uff0c\u6d6a\u8d39\u4e86\u597d\u957f\u65f6\u95f4<a href=\"http:\/\/blog.md5.red\/?p=517\" target=\"_blank\">\u8c03\u8bd5\u73af\u5883<\/a>\u2026\u2026)<\/p>\n<\/form>\n<div>\n<h3>PIN\u548c\u590d\u6742\u5bc6\u7801<\/h3>\n<p>\u5173\u952e\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<div id=\"crayon-568cf930c4208801649398-1\" class=\"crayon-line\"><span class=\"crayon-m\">public<\/span> <span class=\"crayon-t\">byte<\/span><span class=\"crayon-sy\">[<\/span><span class=\"crayon-sy\">]<\/span> <span class=\"crayon-e\">passwordToHash<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-t\">String<\/span> <span class=\"crayon-v\">password<\/span><span class=\"crayon-sy\">)<\/span> <span class=\"crayon-sy\">{<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-2\" class=\"crayon-line crayon-striped-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-st\">if<\/span> <span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">password<\/span> <span class=\"crayon-o\">==<\/span> <span class=\"crayon-t\">null<\/span><span class=\"crayon-sy\">)<\/span> <span class=\"crayon-sy\">{<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-3\" class=\"crayon-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-st\">return<\/span> <span class=\"crayon-t\">null<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-4\" class=\"crayon-line crayon-striped-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-sy\">}<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-5\" class=\"crayon-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-t\">String<\/span> <span class=\"crayon-v\">algo<\/span> <span class=\"crayon-o\">=<\/span> <span class=\"crayon-t\">null<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-6\" class=\"crayon-line crayon-striped-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-t\">byte<\/span><span class=\"crayon-sy\">[<\/span><span class=\"crayon-sy\">]<\/span> <span class=\"crayon-v\">hashed<\/span> <span class=\"crayon-o\">=<\/span> <span class=\"crayon-t\">null<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-7\" class=\"crayon-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-st\">try<\/span> <span class=\"crayon-sy\">{<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-8\" class=\"crayon-line crayon-striped-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-t\">byte<\/span><span class=\"crayon-sy\">[<\/span><span class=\"crayon-sy\">]<\/span> <span class=\"crayon-v\">saltedPassword<\/span> <span class=\"crayon-o\">=<\/span> <span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">password<\/span> <span class=\"crayon-o\">+<\/span> <span class=\"crayon-e\">getSalt<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">.<\/span><span class=\"crayon-e\">getBytes<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-9\" class=\"crayon-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-t\">byte<\/span><span class=\"crayon-sy\">[<\/span><span class=\"crayon-sy\">]<\/span> <span class=\"crayon-v\">sha1<\/span> <span class=\"crayon-o\">=<\/span> <span class=\"crayon-v\">MessageDigest<\/span><span class=\"crayon-sy\">.<\/span><span class=\"crayon-e\">getInstance<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">algo<\/span> <span class=\"crayon-o\">=<\/span> <span class=\"crayon-s\">\"SHA-1\"<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">.<\/span><span class=\"crayon-e\">digest<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">saltedPassword<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-10\" class=\"crayon-line crayon-striped-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-t\">byte<\/span><span class=\"crayon-sy\">[<\/span><span class=\"crayon-sy\">]<\/span> <span class=\"crayon-v\">md5<\/span> <span class=\"crayon-o\">=<\/span> <span class=\"crayon-v\">MessageDigest<\/span><span class=\"crayon-sy\">.<\/span><span class=\"crayon-e\">getInstance<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">algo<\/span> <span class=\"crayon-o\">=<\/span> <span class=\"crayon-s\">\"MD5\"<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">.<\/span><span class=\"crayon-e\">digest<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">saltedPassword<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-11\" class=\"crayon-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-v\">hashed<\/span> <span class=\"crayon-o\">=<\/span> <span class=\"crayon-sy\">(<\/span><span class=\"crayon-e\">toHex<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">sha1<\/span><span class=\"crayon-sy\">)<\/span> <span class=\"crayon-o\">+<\/span> <span class=\"crayon-e\">toHex<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">md5<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">.<\/span><span class=\"crayon-e\">getBytes<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-12\" class=\"crayon-line crayon-striped-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-sy\">}<\/span> <span class=\"crayon-st\">catch<\/span> <span class=\"crayon-sy\">(<\/span><span class=\"crayon-i\">NoSuchAlgorithmException<\/span> <span class=\"crayon-v\">e<\/span><span class=\"crayon-sy\">)<\/span> <span class=\"crayon-sy\">{<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-13\" class=\"crayon-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-v\">Log<\/span><span class=\"crayon-sy\">.<\/span><span class=\"crayon-e\">w<\/span><span class=\"crayon-sy\">(<\/span><span class=\"crayon-v\">TAG<\/span><span class=\"crayon-sy\">,<\/span> <span class=\"crayon-s\">\"Failed to encode string because of missing algorithm: \"<\/span> <span class=\"crayon-o\">+<\/span> <span class=\"crayon-v\">algo<\/span><span class=\"crayon-sy\">)<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-14\" class=\"crayon-line crayon-striped-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-sy\">}<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-15\" class=\"crayon-line\"><span class=\"crayon-h\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/span><span class=\"crayon-st\">return<\/span> <span class=\"crayon-v\">hashed<\/span><span class=\"crayon-sy\">;<\/span><\/div>\n<div id=\"crayon-568cf930c4208801649398-16\" class=\"crayon-line crayon-striped-line\"><span class=\"crayon-sy\">}<\/span><\/div>\n<div class=\"crayon-line crayon-striped-line\">\n<p>\u4ece\u4ee3\u7801\u6765\u770bpassword.key\u4f7f\u7528sha1\u548cMD5\u52a0\u5bc6\uff0c\u6dfb\u52a0\u4e86salt\uff0c\u8fd9\u4e2asalt\u7684\u5f3a\u5ea6\u5f88\u9ad8\uff0c\u5b58\u50a8\u4e8e<\/p>\n<p>\/data\/data\/com.android.providers.settings\/databases\/databasessettings.db\uff08Android 4.0\u53ca\u4ee5\u524d\uff09<\/p>\n<p>\/data\/system\/locksettings.db\uff08Android4.1\u53ca\u4ee5\u540e\uff09<\/p>\n<p>secure\u8868\u7684lockscreen.password_salt\u8fd9\u4e00\u9879\u3002<\/p>\n<p><a href=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/secure.jpg\" class=\"highslide-image\" onclick=\"return hs.expand(this);\" rel=\"attachment wp-att-485\"><img decoding=\"async\" class=\"alignnone wp-image-485\" src=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/secure.jpg\" alt=\"secure\" width=\"639\" height=\"244\" srcset=\"https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/secure.jpg 770w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/secure-300x115.jpg 300w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/secure-768x293.jpg 768w\" sizes=\"(max-width: 639px) 100vw, 639px\" \/><\/a><\/p>\n<p>\u5bc6\u6587\u5219\u5b58\u50a8\u5728\/data\/system\/password.key\u3002<\/p>\n<p>\u8fd9\u79cd\u60c5\u51b5\u4e0b\u6bd4\u4e5d\u5bab\u683c\u5bc6\u7801\u590d\u6742\u5f88\u591a\uff0c\u5e26\u4e86salt\uff0c\u65e0\u6cd5\u505a\u5b57\u5178\u4e86\u3002\u5177\u4f53\u5206\u4e3a\u4e09\u79cd\u60c5\u51b5\u6d4b\u8bd5\u3002<\/p>\n<p>&nbsp;<\/p>\n<\/div>\n<p><strong>1\u3001\u5df2\u7ecf\u8fdb\u5165\u7cfb\u7edf\u3002<\/strong><\/p>\n<p>\u6d4b\u8bd5\u624b\u673a\uff1a\u4e09\u661f S3<\/p>\n<p>\u8fd9\u79cd\u60c5\u51b5\uff0c\u4f8b\u5982\u5f00\u4e86\u8c03\u8bd5\u6a21\u5f0f\u4e5froot\u8fc7\uff0c\u80fd\u591f\u6210\u529f\u8fde\u63a5\u7535\u8111\uff0c\u6216\u8005\u67d0\u4e9b\u7279\u5b9a\u673a\u578b\u53ef\u4ee5\u901a\u8fc7COM\u53e3\u8bbf\u95ee\u5b58\u50a8\u5185\u5bb9\u7b49\u7b49\u3002<\/p>\n<p>\u5b9e\u9645\u6d4b\u8bd5\uff1a<\/p>\n<p>\u8bbe\u7f6ePIN\u5bc6\u7801\u4e3a\u201c1234\u201d\uff0cpassword.key\u5bc6\u6587\u4e3a\u201cCA0DC9C8E828442DD1D446376A0FA470EF812088\u201d\uff0c\u53ea\u670940\u4f4d\uff0c\u4e0d\u5bf9\u554a\uff0c\u4e0d\u662f\u5e94\u8be572\u4f4d\u4e48\uff1f\u96be\u9053\u4e09\u661f\u53ea\u7528\u4e86sha1\uff1f<\/p>\n<p><a href=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/key-1.jpg\" class=\"highslide-image\" onclick=\"return hs.expand(this);\" rel=\"attachment wp-att-487\"><img decoding=\"async\" class=\"alignnone size-full wp-image-487\" src=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/key-1.jpg\" alt=\"key\" width=\"416\" height=\"97\" srcset=\"https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/key-1.jpg 416w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/key-1-300x70.jpg 300w\" sizes=\"(max-width: 416px) 100vw, 416px\" \/><\/a><\/p>\n<p>salt\u4e3a\u201c6545741435738626456\u201d\uff0c<strong>\u8981\u7528\u8fd9\u4e2asalt\u5148\u5f97\u8f6c\u6362\u4e3a\u5341\u516d\u8fdb\u5236\uff0c\u7136\u540e\u82f1\u6587\u5168\u90e8\u8f6c\u6362\u4e3a\u5c0f\u5199<\/strong>\u3002<\/p>\n<table class=\"default\" border=\"1\" frame=\"box\" cellspacing=\"0\" bgcolor=\"#FFFFFF\">\n<tbody>\n<tr class=\"header\">\n<th align=\"left\" bgcolor=\"#F0F0F0\" width=\"50px\" height=\"19px\">_id<\/th>\n<th align=\"left\" bgcolor=\"#F0F0F0\" width=\"206px\" height=\"19px\">name<\/th>\n<th align=\"left\" bgcolor=\"#F0F0F0\" width=\"300px\" height=\"19px\">value<\/th>\n<\/tr>\n<tr class=\"default\">\n<td class=\"normalborder\" align=\"left\" height=\"18px\">132<\/td>\n<td class=\"normalborder\" align=\"left\" height=\"18px\">lockscreen.password_salt<\/td>\n<td class=\"normalborder\" align=\"left\" height=\"18px\">6545741435738626456<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>python\u4ee3\u7801\uff1areturnedsalt = \u00a0binascii.hexlify(struct.pack('&gt;q', int(salt) ))<\/p>\n<p>\u8f6c\u6362\u540e\u4e3a\u201c5ad72527acc19998\u201d\u3002<\/p>\n<p>sha1(12345ad72527acc19998)=549c3f339fc3ec8da7b5112ae6cec23cca2d0cdf<\/p>\n<p>\u5947\u602a\uff0c\u600e\u4e48\u4e0d\u662f\u201cCA0DC9C8E828442DD1D446376A0FA470EF812088\u201d\u3002<\/p>\n<p><strong>\u56e0\u4e3a\u4e09\u661f\u8fd9\u4e2a\u5927\u8d31\u8d27\u505a\u4e86\u4fee\u6539\uff0c\u6ca1\u7528\u539f\u751f\u7684\u7a0b\u5e8f\u2026\u2026\u505a\u4e861024\u6b21sha1\u8fd0\u7b97\uff0c\u5177\u4f53\u53ef\u4ee5\u770b\u9644\u5f55\u7684\u52a0\u5bc6\u6d41\u7a0b\u3002<\/strong><\/p>\n<p>\u4e0d\u8fc7\u62ff\u5230hash\u548csalt\uff0c\u76f4\u63a5\u53ef\u4ee5\u7528<a href=\"http:\/\/hashcat.net\/wiki\/doku.php?id=example_hashes\" target=\"_blank\">hashcat<\/a>\u8dd1\u4e86\uff0c\u4e13\u95e8\u63d0\u4f9b\u4e86\u9488\u5bf9\u4e09\u661f\u7684\u7834\u89e3\u3002<\/p>\n<p>\u547d\u4ee4\uff1acudaHashcat64.exe -m 5800 CA0DC9C8E828442DD1D446376A0FA470EF812088:5ad72527acc19998 -a 3 ?d?d?d?d<\/p>\n<p><a href=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/hashcatSamsung.jpg\" class=\"highslide-image\" onclick=\"return hs.expand(this);\" rel=\"attachment wp-att-496\"><img decoding=\"async\" class=\"alignnone size-full wp-image-496\" src=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/hashcatSamsung.jpg\" alt=\"hashcatSamsung\" width=\"519\" height=\"292\" srcset=\"https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/hashcatSamsung.jpg 519w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/hashcatSamsung-300x169.jpg 300w\" sizes=\"(max-width: 519px) 100vw, 519px\" \/><\/a><\/p>\n<p>&nbsp;<\/p>\n<p><strong>2\u3001\u672a\u8fdb\u5165\u7cfb\u7edf\u3002<\/strong><\/p>\n<p>\u6d4b\u8bd5\u624b\u673a\uff1a\u4e2d\u5174 ZTE V970\u3002<\/p>\n<p>\u8fd9\u79cd\u60c5\u51b5\u7c7b\u4f3c\u4e8e\uff0cJTAG\u53d6\u955c\u50cf\uff0c\u8bfb\u82af\u7247\uff0cRecovery\u6a21\u5f0f\u8bfb\u5b58\u50a8\u5206\u533a\u3002<\/p>\n<p>\u8fd9\u65f6password.key\u662f72\u5b57\u8282\uff0c\u6b63\u5e38\u7684\uff0c\u5176\u4e2d\u524d40\u5b57\u8282\u662fsha1,32\u5b57\u8282\u662fmd5\u3002<\/p>\n<p><a href=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/ztehash.jpg\" class=\"highslide-image\" onclick=\"return hs.expand(this);\" rel=\"attachment wp-att-491\"><img decoding=\"async\" class=\"alignnone size-full wp-image-491\" src=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/ztehash.jpg\" alt=\"ztehash\" width=\"808\" height=\"81\" srcset=\"https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/ztehash.jpg 808w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/ztehash-300x30.jpg 300w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/ztehash-768x77.jpg 768w\" sizes=\"(max-width: 808px) 100vw, 808px\" \/><\/a><\/p>\n<p>\u5bc6\u6587\u201c36E8759BA3346F604DC15A6A184D79C64035F0879AE702616BEEEC1ADEACF1ABC9A1263A\u201d<\/p>\n<p>SHA1 hash \"36E8759BA3346F604DC15A6A184D79C64035F087\"<\/p>\n<p>MD5 hash \u201c9AE702616BEEEC1ADEACF1ABC9A1263A\u201d<\/p>\n<p>salt \"2312160962934435513\"\uff0c\u8f6c\u6362\u540e\u4e3a\u201c201672253b3b6eb9\u201d<\/p>\n<p><a href=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/zte-hash.jpg\" class=\"highslide-image\" onclick=\"return hs.expand(this);\" rel=\"attachment wp-att-492\"><img decoding=\"async\" class=\"alignnone wp-image-492\" src=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/zte-hash.jpg\" alt=\"zte hash\" width=\"584\" height=\"255\" srcset=\"https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/zte-hash.jpg 664w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/zte-hash-300x131.jpg 300w\" sizes=\"(max-width: 584px) 100vw, 584px\" \/><\/a><\/p>\n<p>&nbsp;<\/p>\n<p>\u62ff\u5230salt\u548c\u5bc6\u6587\u540e\u53ef\u4ee5\u7528 <a href=\"http:\/\/blog.md5.red\/?p=472\" target=\"_blank\">hashcat<\/a> \u66b4\u529b\u7834\u89e3\uff0cMD5\u901f\u5ea6\u5feb\uff0c\u5c31\u7528MD5\u8dd1\uff1a<\/p>\n<p>cudaHashcat64.exe -m 10 9AE702616BEEEC1ADEACF1ABC9A1263A:201672253b3b6eb9 -a 3 ?d?d?d?d<\/p>\n<p><img decoding=\"async\" class=\"alignnone size-full wp-image-495\" src=\"http:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/hashcatmd5.jpg\" alt=\"hashcatmd5\" width=\"520\" height=\"263\" srcset=\"https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/hashcatmd5.jpg 520w, https:\/\/blog.md5.red\/wp-content\/uploads\/2016\/01\/hashcatmd5-300x152.jpg 300w\" sizes=\"(max-width: 520px) 100vw, 520px\" \/><\/p>\n<p>&nbsp;<\/p>\n<p><strong>3\u3001Android 4.1\u4ee5\u540e<\/strong><\/p>\n<p>\u652f\u6301\u591a\u7528\u6237\uff0c\u6bcf\u4e2a\u7528\u6237\u7684salt\u4e0d\u4e00\u6837\uff0c\u9700\u8981select value from locksettings where name='lockscreen.password_salt' and user=number\uff0c\u5176\u4ed6\u7834\u89e3\u65b9\u6cd5\u76f8\u540c\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>BTW\uff1a\u4e0d\u5f97\u4e0d\u611f\u6168\uff0c\u8001\u5916\u5206\u6790\u5f97\u7684\u786e\u900f\u5f7b\uff01\u53d7\u76ca\u826f\u591a\uff01<\/p>\n<p><strong>\u9644\u5f55\uff1a<\/strong><\/p>\n<h4>\u9ad8\u624b\u9006\u5411\u7684\u4e09\u661f\u7684\u52a0\u5bc6\u6d41\u7a0b<\/h4>\n<p><i>public byte[] passwordToHash(String paramString)<\/i><br \/>\n<i>\u00a0 {<\/i><br \/>\n<i>\u00a0 \u00a0 if (paramString == null)<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 return null;<\/i><br \/>\n<i>\u00a0 \u00a0 String str = null;<\/i><br \/>\n<i>\u00a0 \u00a0 byte[] arrayOfByte1 = null;<\/i><br \/>\n<i>\u00a0 \u00a0 try<\/i><br \/>\n<i>\u00a0 \u00a0 {<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 byte[] arrayOfByte2 = (paramString + getSalt()).getBytes();<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 byte[] arrayOfByte3 = null;<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 str = \"SHA-1\";<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 MessageDigest localMessageDigest = MessageDigest.getInstance(str);<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 long l1 = System.currentTimeMillis();<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 for (int i = 0; i &lt; 1024; i++)<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 {<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 \u00a0 arrayOfByte1 = null;<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 \u00a0 if (arrayOfByte3 != null)<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 localMessageDigest.update(arrayOfByte3);<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 \u00a0 localMessageDigest.update((\"\" + i).getBytes());<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 \u00a0 localMessageDigest.update(arrayOfByte2);<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 \u00a0 arrayOfByte3 = localMessageDigest.digest();<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 }<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 arrayOfByte1 = toHex(arrayOfByte3).getBytes();<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 long l2 = System.currentTimeMillis();<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 Log.w(\"LockPatternUtils\", \"passwordToHash time = \" + (l2 - l1) + \"ms\");<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 return arrayOfByte1;<\/i><br \/>\n<i>\u00a0 \u00a0 }<\/i><br \/>\n<i>\u00a0 \u00a0 catch (NoSuchAlgorithmException localNoSuchAlgorithmException)<\/i><br \/>\n<i>\u00a0 \u00a0 {<\/i><br \/>\n<i>\u00a0 \u00a0 \u00a0 Log.w(\"LockPatternUtils\", \"Failed to encode string because of missing algorithm: \" + str);<\/i><br \/>\n<i>\u00a0 \u00a0 }<\/i><br \/>\n<i>\u00a0 \u00a0 return arrayOfByte1;<\/i><br \/>\n<i>\u00a0 }<\/i><\/p>\n<\/div>\n<\/div>\n<p>&nbsp;<\/p>\n<h4>password.py<\/h4>\n<p><em>import os, sys, subprocess, binascii, struct<\/em><br \/>\n<em> import sqlite3 as lite<\/em><\/p>\n<p><em>salt='2312160962934435513'<\/em><br \/>\n<em> returnedsalt = binascii.hexlify(struct.pack('&gt;q', int(salt) ))<\/em><br \/>\n<em> print returnedsalt<\/em><br \/>\n<em> sha1hash = 'CA0DC9C8E828442DD1D446376A0FA470EF812088'<\/em><\/p>\n<p>&nbsp;<\/p>\n<div class=\"content\">\n<div>\n<p>\u53c2\u8003\u8d44\u6599\uff1a<\/p>\n<p><a href=\"http:\/\/bbs.pediy.com\/showthread.php?t=166933\" target=\"_blank\">http:\/\/bbs.pediy.com\/showthread.php?t=166933<\/a><\/p>\n<p><a href=\"http:\/\/www.freebuf.com\/articles\/terminal\/31176.html\" target=\"_blank\">http:\/\/www.freebuf.com\/articles\/terminal\/31176.html<\/a><\/p>\n<p><a href=\"http:\/\/forensics.spreitzenbarth.de\/2012\/02\/28\/cracking-pin-and-password-locks-on-android\/\" target=\"_blank\">http:\/\/forensics.spreitzenbarth.de\/2012\/02\/28\/cracking-pin-and-password-locks-on-android\/<\/a><\/p>\n<p><a href=\"https:\/\/www.pentestpartners.com\/blog\/cracking-android-passwords-a-how-to\/\" target=\"_blank\">https:\/\/www.pentestpartners.com\/blog\/cracking-android-passwords-a-how-to\/<\/a><\/p>\n<p><a href=\"https:\/\/hashcat.net\/forum\/thread-2202.html\" target=\"_blank\">https:\/\/hashcat.net\/forum\/thread-2202.html<\/a><\/p>\n<p><a href=\"http:\/\/khorchanov.blogspot.hk\/2013\/07\/cracking-android-devices-pin-lock.html\" target=\"_blank\">http:\/\/khorchanov.blogspot.hk\/2013\/07\/cracking-android-devices-pin-lock.html<\/a><\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u4e5d\u5bab\u683c\u5bc6\u7801 \u5bc6\u6587\u5b58\u50a8\u4e8e\uff1a\/data\/system\/gesture.key \u3002\u4f7f\u7528sha1\u52a0\u5bc6\uff0c\u5bf9\u5e94\u4f4d\u7f6e\u8868\u793a\u7684\u6570 ...<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4],"tags":[39,63,64,6],"class_list":["post-456","post","type-post","status-publish","format-standard","hentry","category-4","tag-android","tag-gesture-key","tag-password-key","tag-6"],"_links":{"self":[{"href":"https:\/\/blog.md5.red\/index.php?rest_route=\/wp\/v2\/posts\/456","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.md5.red\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.md5.red\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.md5.red\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.md5.red\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=456"}],"version-history":[{"count":29,"href":"https:\/\/blog.md5.red\/index.php?rest_route=\/wp\/v2\/posts\/456\/revisions"}],"predecessor-version":[{"id":645,"href":"https:\/\/blog.md5.red\/index.php?rest_route=\/wp\/v2\/posts\/456\/revisions\/645"}],"wp:attachment":[{"href":"https:\/\/blog.md5.red\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=456"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.md5.red\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=456"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.md5.red\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=456"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}