2

We are told to use password that are long with high complexity to prevent attackers from using brute force attacks on our accounts

The thing is that many websites will pick this up and either enforce timings e.g. 30 seconds between tries or lock you out altogether. In this scenario is a high complexity password worth the effort and the associated risk of a password safe or manager

Please assume the password is not easily guessed. Also this is not referring to scenario's were brute force attacks could happen like an excel file or some middleware that could be copied

user1605665
  • 173
  • 1
  • 6
  • "The thing is that most websites will pick this up and either enforce timings e.g. 30 seconds between tries or lock you out altogether." - Do you have evidence for that? – Arminius Aug 17 '17 at 22:20
  • Good point, changed to many. So mabey there is a different scenario where the website does not have basic hacking prevention features. If you enter your password wrong a number of times on your bank account its likely you will be locked out and need to call them. Yes regulated industries tend to be better. – user1605665 Aug 17 '17 at 22:38
  • i think "guessing" a password is easier than you think these days, given one can try millions per second – dandavis Aug 19 '17 at 12:06
  • @dandavis if the website is setup with some basic security options then you cannot try millions of times as you will be blocked. The top two answers explain the real concern – user1605665 Aug 20 '17 at 22:06
  • @user1605665 s/regulated industries/industries with lots of tech-aware attorneys/ – Skaperen Sep 03 '17 at 05:21

3 Answers3

5

There are two parts to your concern about password length, the threat model and the rationale behind longer passwords. As you state, a lot of websites have protections against common attacks, and if the password database hasn't been leaked, your password isn't easily guessable, and online protections against brute-force protections are in place, longer passwords don't make much of a difference. When those assumptions fail, long passwords can make sure your password is too expensive to crack, as demonstrated in research. The more general case of this question, "Why have strong passwords at all?", is covered in this question.

Threat Model

The threat most password policies are concerned with is an attacker trying to crack the hash of the password which has been stolen or leaked from the system, also known as an offline attack. This usually has some of the strictest requirements. However, these offline attacks aren't the only threat model. You password could be compromised in other ways, like:

  • Brute-force on the website itself, as you mentioned: Most secure websites have protections against this, which are further discussed below. Long passwords do help you from online brute-force attacks, although the cost/attempt is much higher than an offline password cracker. These kind of attacks are somewhat common.
  • You reused a password and the password was compromised elsewhere: The only prevention here is to not reuse passwords. Password length won't help here and too stringent of password requirements might even discourage users from setting a different password for each site.
  • A friend, colleague, or social engineer is trying to guess your password based on their knowledge of you: While password length helps here, you don't need very long passwords to stop this attack, and often services are rate limited to only a few attempts per hour per computer.
  • There are also methods like phishing, exploiting the password reset, and stealing a plaintext database. In all of those threats it doesn't matter how complicated your password is; it's gone anyways.

Focusing just on online attacks and limiting log-in attempts is bad practice because password database leaks do happen. LinkedIn, MySpace, Adobe, Dropbox, and others have all had password hashes stolen. You can check if you appear on any public leaks here.

Don't Websites Block Online Brute-Force Attempts?

A major part of your question appears to be why password requirements are such a big deal if protections against brute-force attacks are in place. PCI compliance, for example, requires account lock-out for at least 30 minutes after 6 failed attempts. The biggest problem in preventing these attacks is working against botnets with thousands of computers without causing a denial of service. How do you prevent thousands of computers each trying to log in a few times without also locking out the user when they mistype their password while using a new computer, or using the same proxy as the botnet?

There are other ways other than lockouts to rate-limit attackers, like asking for CAPTCHA. However, there are some ways to work around CAPTCHA. This OWASP page discusses more of the best ways to block brute-force attacks.

Why Longer Passwords Help

A few decades ago when Unix was king, it was considered that five-character passwords were pretty good. Now the stakes are higher, advanced hardware is cheap, and hashes can be broken faster than ever so the requirements for good passwords are higher. This is part of the reason more companies are pushing for longer passwords.

Longer passwords help because the difficulty of password cracking goes up exponentially with password complexity. Just adding one random word to your password can make it thousands of times more expensive to guess- the difference between seconds and hours of cracking time. Adding another random word turns those hours into years.

Many people advocate for using symbols and creating passwords from larger and larger character sets to make passwords more difficult to crack. However, several examples in research show that requiring longer passwords instead of very complex passwords leads to harder-to-crack passwords (and is more user friendly). The longer passwords side was also famously supported by xkcd's "correct horse" method to generate passwords.

One caveat is that longer passwords aren't always more secure since extra characters can make a password more predictable. "orrect horse battery staple" is more secure than "correct horse battery staple", although the latter is much more memorable. Good password meters like Telepathwords or zxcvbn take this into account and will warn you when the extra characters are predictable.

How Long Should Passwords Be?

The specifics of how long your password has to be, and how hard it is to crack, can't be answered without knowing how your password is generated, how the password is hashed on the server, and the attacker's resources. For more details see this question.

I'll warn you, that password policy is a matter of opinion. I've tried to show the best solution based on research, but there are some experts who disagree with me.

Cody P
  • 1,148
  • 6
  • 14
4

Yes it is worth the "effort". Remember, length is your friend, you do not have to make it harder on yourself by using random letters, symbols and numbers, use a easily remembered long phrase or password manager.

Also, I think you are looking at the wrong attack vector. When I think of why I should use a good password, I immediately think because some website's database is going to be compromised and the attacker is going to have a hash of my password with all the time in the world to brute-force it. So if you think in terms of that then it should convince you more on why a strong password is worth the effort. Unless an attacker has a specific reason to go after you, they probably aren't going to waste their time with a login form on a website, they are going for databases

If you use a simple or short password then the hash might already have been cracked. Unless you are dealing with a persistent actor then attackers usually go for low hanging fruit, meaning if they have a database of hashes, they are going to crack all easy ones and get what they can and make a quick buck. This also reinforces the use of a password manager because if you reuse passwords across multiple accounts then you just made the attackers life easier and that is where password managers are extremely helpful.

nd510
  • 1,748
  • 1
  • 10
  • 15
0

You need a certain level of complexity, but many of the proposed rules do not contribute to that. See instead https://xkcd.com/936/ and two-factor authentication that isn't trivial to spoof.

davecb
  • 313
  • 1
  • 6