• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

octomagon/davegrohl: A Password Cracker for macOS

原作者: [db:作者] 来自: 网络 收藏 邀请

开源软件名称(OpenSource Name):

octomagon/davegrohl

开源软件地址(OpenSource Url):

https://github.com/octomagon/davegrohl

开源编程语言(OpenSource Language):

C 86.4%

开源软件介绍(OpenSource Introduction):

DaveGrohl 3.01 alpha

A Distributed Password Cracker for OS X

Build Status

What's new?

Version 3.0 is a complete rewrite of DaveGrohl. Version 2 was suffering from a severe case of code-stank and it will eventually be euthanized. The goal is to create a completely modern object-oriented codebase and make it extremely easy to use for both the developer and the end user. This code is currently in the very early stages, but will focus on a few central design goals.

Design Goals

  • Ease of Use - At first the UI will mimic V2, but the user experience is the most important design aspect. Users at any level of expertise should easily be able to figure out how to compile, install and run Dave.
  • Platform Independence - It should compile on Mac OS X and the most common flavors of Linux (Ubuntu, Red Hat) with no modification. Compiling on Windows is a plus but by no means a goal.
  • Code Independence - It should require no external libraries outside of the C++ Standard Library to compile. If better libraries are available, Dave should auto-detect and link against them with no flags required. User experience should never be a sacrifice.
  • Self Documenting - If anyone can’t figure out how to use Dave, it is at best a bug and at worst a fundamental design flaw. Dave should realize the user is having trouble offer help. (The current UI is not necessarily the goal UI)
  • Modern Codebase - Dave should be completely object-oriented and using the most modern C++11/14 standards. If dropping to raw C or even assembly would present a performance benefit, that code should be carefully implemented and encapsulated. Any Objective-C should be replaced with Swift and ideally phased out completely.

Quick How-To

If you're pulling Dave from Github, make sure XCode is installed then clone the repository.

MacBook-Pro:~$ git clone https://github.com/octomagon/davegrohl.git

Compile away...

MacBook-Pro:~$ cd davegrohl
MacBook-Pro:~/davegrohl$ make

*** A bunch of stuff happens here ***

Make succeeded...
Created: dave
MacBook-Pro:~/davegrohl$ 

Then run Dave. Press spacebar to see the progress of each thread. Threads running a dictionary attack will be in () while incremental attacks will be in []. For dictionary attacks, Dave looks in a folder called 'wordlists' for plain text files and will dedicate a thread for each file it finds.

MacBook-Pro:~/davegrohl$ sudo ./dave -u someuser
-- Loaded PBKDF2 (Salted SHA512) hash...
-- Starting attack

      TIME             GUESSES
0000:00:08                 351  (aaru) (loveme) [x] [86n] [bpc] [2s5] [ojf] [wkea] [52la] [caha] 
0000:00:14                 613  (abaculus) (samantha) [9a] [38n] [t3c] [an5] [yjf] [k4ea] [dmla] [ieha] 
0000:00:20                 875  (abandoning) (spongebob) [pe] [n7n] [x3c] [8n5] [bvf] [25ea] [odla] [weha] 

-- Found password : 'shorty'
-- (dictionary attack)

Finished in 31.330 seconds / 1,318 guesses...
42 guesses per second.

In this example, I purposely set my password to one I knew Dave would guess early. When using PBKDF2, OS X throttles the time it takes to hash a password. This is great for password security, but bad for brute force attacks.

Out of the box, Dave will not check every possible password because it is insanely impractical. With no special arguments, Dave will check every password between 0 and 16 digits long using the default character set of 'aeorisn1tl2md0cp3hbuk45g9687yfwjvzxq'. With these settings on my 8-core Macbook Pro, it would take longer than the age of the universe to check every possibility.

You can greatly improve your time-to-crack if you have an idea of how long the password is and what characters may be in it. The following example tells Dave the password is between 5 & 7 digits long and may contain the characters 'sbeio'.

MacBook-Pro:~/davegrohl$ sudo ./dave -c sbeio -m 5 -M 7 -u someuser
Password:
-- Loaded PBKDF2 (Salted SHA512) hash...
-- Starting attack

      TIME             GUESSES
0000:00:07                 245  (aardwolves) (chocolate) [oosss] [oossbe] [ssbsess] [oossiis] [ssbsobb]
0000:00:20                 682  (abaiser) (666666) [iiess] [eiesbe] [iiesess] [iiesiis] [iiesobb]

You can get a time estimate by pressing 't'.

0000:00:27                 894  1 Hour 26 Seconds left...
0000:00:34               1,152  (abashes) (sayang) [oeoss] [oeosbe] [siosess] [siosiis] [siosobb]

-- Found password : 'boobs'
-- (incremental attack)

Finished in 74.250 seconds / 2,477 guesses...
33 guesses per second.

The time estimate is how long Dave will take to check every possibility, not how long to find the password.

Using Dave with Hashcat

If you'd like to use a real password cracker, try hashcat.

You can use Dave to extract a user's hash formatted for hashcat. Like this:

MacBook-Pro:~/davegrohl$ sudo ./dave --hashcat=USERNAME > hash.txt
MacBook-Pro:~/davegrohl$ hashcat -m 7100 hash.txt wordlist.txt

History

DaveGrohl was initially created in early 2011 as a password hash extractor & companion tool to John the Ripper. It's blossoming into a multithreaded distributed password cracker was a product of sheer curiosity/boredom. Dave has always been aimed at brute-forcing OS X user passwords, although he's been known to get lost staring into a cloud of Linux machines.

Sadly, my day job as a ninja spy astronaut and my highly Scandinavian level of ethanol consumption has led to an old stanky code base. In light of these facts, I've decided to unleash the stank upon the world in hopes that it brings joy and nerdgasms to whomever finds it.

Vintage Code

The old version of Dave is still available. It's currently the most stable and may have some features that have not yet been implemented in V3.

MacBook-Pro:~$ git clone https://github.com/octomagon/davegrohl-old.git

Why Distributed?

Distributed mode in V2 stopped working an OS or two ago. I sadly haven't had the time to look into it, although it's probably something simple.

Also while distributed mode was cool, it was not built to scale massively. This is partly due to it's being tied to Mac OS X. Who the hell wants to virtualize a thousand instances of OS X anyways? Real scale means linux. If DaveGrohl is destined to live on, it should be stripped of it's Cocoa and start embracing platform independence.

Not Windows of course... Fuck Windows.

Disclaimer

Although Dave is mostly in C++11 & Objective-C, I have never coded professionally in those languages. If while reading the code you start to get a nosebleed or an erection lasting more than 4 hours, please accept my sincere apologies for my mockery of good coding practices.




鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap