29

I'm considering implementing a pattern for my passwords, using the following ideas:

  1. Master password that I store nowhere
  2. An algorithm to mangle it based on the site I am accessing

So for example I have master password M, I go to website PayPal (P) and run some relatively simple algorithm in my head A(M, P) that produces password for PayPal. Algorithm is consistent but for different sites it produces different results.

Pros:

  1. Stealing 1 or 2 passwords doesn't expose me to further risk.
  2. I don't need any storage or password management apps.
  3. Keylogger can steal only limited amount of passwords.
  4. Since I don't need storage I can't really lose my passwords.

Cons:

  1. If my algorithm somehow leaks the master password can be recovered from few known passwords.
  2. It makes entering passwords harder. I can write small app for my phone for that though. Still generating site password might be problematic in certain situations.
  3. Changing passwords is a problem as well, but this can be added by adding 3rd param - version A(M, P, V) and I can store just version. Or save it in password hint.

Is it good idea?

Andrey
  • 561
  • 4
  • 9
  • 4
    I've flagged as a duplicate, but in the meantime I like [this answer](http://security.stackexchange.com/a/94128/93625) from a very closely related question: your scheme would be no safer than a password manager, would add no significant advantages, and would suffer significant disadvantages. So why bother? – Ben Jun 03 '16 at 05:00
  • 5
    Your pro number 1 is **highly dubious** and strictly depends on the algorithm. If for example the algorithm is just adding the name of the site with few modifications tot he original password than the answer is surely no. The algorithm should be such that the master password nor portions of it appear in the generated per site password (e.g. `M=MasterPwd`, `P=PayPal`, `A(M,P)=laPrewMa#%62` versus a bad `A(M,P) = P4yPallyMasterPallyPwd` With something like the latter probably having 2[or even 1] per-site passwords already leaks the master one). – Bakuriu Jun 03 '16 at 08:28
  • 1
    related: http://security.stackexchange.com/questions/115739/is-this-use-of-pbkdf2-for-generating-passwords-secure – Jacco Jun 03 '16 at 10:27
  • @Ben it is not exact duplicate, it is similar idea but my point is to make hashing/mangling possible in a person's head or on a piece of paper, so it eliminates a crucial disadvantage - need to ever enter your master password. And advantage over password manager is obvious - you don't need to have access to password database (like on public computers). – Andrey Jun 03 '16 at 11:43
  • 8
    I think your scheme might be scuppered by the inconsistent and annoying password limitations that many websites impose. If you have to have a password between 6 and 12 characters for one site and with a minimum of 12 for another site your algorithm may become to complex to remember. Similarly some sites require special characters in a password and some don't allow them at all; the list of perverse restrictions is mind boggling. – Mark_1 Jun 03 '16 at 12:32
  • 1
    @Andrey algorithms that are simple enough to run in your head is most likely not cryptographically strong enough to resist cryptanalysis. – Lie Ryan Jun 03 '16 at 13:29
  • @LieRyan it is definitely not cryptostrong, not even remotely. But the thing is that it is unlikely that 1) hacker gets access to enough of my passwords 2) they know that there is a rule and those are not random passwords. I have some ideas how to mangle them well enough that it doesn't catch an eye. – Andrey Jun 03 '16 at 13:51
  • 1
    @Mark_1 Adding to your list, I've come across sites which impose a limit of 8 characters. The headaches are endless. – MonkeyZeus Jun 03 '16 at 16:05
  • 1
    @Andrey, you don't need a mangling scheme that is "enough that it doesn't catch an eye." You one that is enough that a *computer* cannot find any patterns in it, trying tens of thousands to millions or more patterns. And you need one that *no other person* has ever thought of, unless you use a cryptographically secure algorithm, because if *you're* smart enough, alone, to come up with the algorithm, you can be sure at least one person in a large criminal organization can also think of it, or find someone talking about it online. "Anyone...can create an algorithm that he himself can't break." – Ben Jun 03 '16 at 16:06
  • for 3), using a scheme is immaterial for keyloggers, since they operate on what you type in (or copy, or a couple of other things). A keylogger can theoretically steal **all** your passwords if it's present long enough, whether you apply a scheme or use a completely random password. Why did you think a scheme would help against a keylogger? Keyloggers are really just a method to steal passwords, so it's really a special case of 1 (one that gets more passwords as time goes on). – Clockwork-Muse Jun 04 '16 at 13:45
  • @Clockwork-Muse I am more concerned about keyloggers on public machines, where I am unlikely to enter a lot of passwords. My scheme helps against keyloggers in comparison to having password manager, because I never enter master password anywhere. – Andrey Jun 04 '16 at 22:22
  • If you're worried about a public machine, you wouldn't download the password manager onto it in the first place; the worry isn't about it compromising the master password (since that's useless on its own), but that it would be able to compromise the entire database after decryption. If you're dealing with a potentially compromised machine like that, you have a different threat model and mitigations to consider (for example, using two-factor authentication). – Clockwork-Muse Jun 04 '16 at 23:00
  • Related work [Publishable Humanly Usable Secure Password Creation Schemas](http://www.cc.gatech.edu/~vempala/papers/phuspcs.pdf): – Jedi Sep 27 '16 at 20:54

8 Answers8

38

Since the question has been edited to no longer reference "Two Factor Authentication", I will re-vamp my answer, but I'll leave the original below.


The idea of having a "base password" that you either append a few chars to, or "mangle" in some way to make it unique for each site is a fairly common trick that even some security experts use (until they adopt password managers at least).

So how secure is this scheme? Well, it's better than using the same password for everything, and worse than using completely different and unrelated passwords. Exactly where it falls on this line is a matter of opinion (which I'm sure other answers will provide).

My opinion is that it doesn't matter where it is on the line because you're either worried about people analyzing your leaked passwords for patterns, or you're not. The way I see it, there are two types of attacks (or "threat models") to worry about:

  1. A "drive-by" dictionary attack by a mass cracking tool using stock dictionaries. They are usually looking to pick off the 40% of users with weak passwords - who re-use the same password from site to site, and then they'll move on to a new password leak.

  2. You are being personally targeted - human time and computational power will be spent analyzing your previous leaked passwords looking for a pattern.

If you're only worried about 1) then you may be able to get away with a very simple mangling rule to get your password away from standard rules in off-the-shelf dictionary-based cracking tools. Even here, you're hoping that your "trick" is not popular enough that any hackers out there have added it to their rule sets. If you're worried about 2) then any sort of pattern whatsoever will eventually be figured out.

At the end of the day, "is it secure enough?" depends on your risk management and the importance of the thing you're protecting: very roughly speaking, if (probability of breach) X (value of data lost) > (level of security) then you should increase your security. If you're concerned enough about your passwords to write up a post on a site like this (and good for you!) then you should consider just using a password manager like LastPass or KeePass - they really are easy (unless you forget your super-strong master password and abandon the whole thing like I did).


Original answer:

First, some terminology:

It turns out that there's a little bit more to Two Factor Authentication than you might think on the surface. Generally speaking, there are three types of authentication mechanisms:

  1. Something you know - information, like a password, or your mother's maiden name, or a public key stored in a key file.

  2. Something you have - usually a physical object like the phone that can receive SMS at your number, or a One-Time-Password (OTP) token or public-key enabled smart card / USB stick:

  1. Something you are: aka "biometric" like fingerprints, iris, voice, typing rhythm, etc.

The reason for splitting auth methods into these categories is that each one requires a very different kind of theft in order for a hacker to acquire it.

If you are required to provide a proof of identity from more than one of the above catogories, then it is properly "Two Factor Authentication", or "Multi-Factor Authentication". If you are providing multiple items from the same category, then it's called "Multi-Step Authentication", which is obviously weaker than multi-factor.

Now for your question:

So what you are proposing is not Multi-Factor. It's not even Multi-Step because at the end of it all, you're only providing one password to the login page.

Mike Ounsworth
  • 58,107
  • 21
  • 154
  • 209
  • How about using a mnemonic to create the super strong master password? For example, think of a simple memorable word, like "deadbeef" and then for each character, add the very first word you think of: (d) - dame. (e) - evil, (a) - ambassador, (d) - dame, (b) - boolean, (e) - evil, (e) - evil, (f) - fail. So the final password would be "dameevilambassadordamebooleanevilevilfail" – Juha Untinen Jun 03 '16 at 06:28
  • 2
    @JuhaUntinen: This is very unreliable. Good luck trying to guess your master password from "deadbeef" in a couple of weeks, when new words will jump to memory for those letters. :) – Sergio Tulentsev Jun 03 '16 at 09:42
  • Thanks for terminology clarifications. Unfortunately the part when you address my scheme is not answering my question fully. Using password managers has significant 2 disadvantages that my proposal tried to fix - 1) you need to be able to access your password manager which is not always possible 2) If your master pwd is stolen you are in trouble. My scheme tries to eliminate both points. – Andrey Jun 03 '16 at 11:52
  • 1
    @Andrey I added a section addressing your comment. At the end of the day, do what you want, but you're not going to know that a trick-based scheme will never be as secure as using different random 32-char passwords for everything. – Mike Ounsworth Jun 03 '16 at 13:20
  • @MikeOunsworth it will never be secure but unless I am not a target of special operation my generated passwords won't catch an eye for pattern. Especially if we are talking about some stupid mass hacking tool. – Andrey Jun 03 '16 at 13:55
  • @Andrey Right. If the threat level you are worried about is mass hacking tools, then your scheme is fine. In fact, appending the first and last letter of the website name to your master password would also be fine since it won't be in the dictionaries. – Mike Ounsworth Jun 03 '16 at 14:02
  • @MikeOunsworth for this 2 stolen passwords would be just enough, if not 1. – Andrey Jun 03 '16 at 14:12
  • 1
    @Andrey But but but you just said that you're not worried about being targeted, you're only worried about "stupid mass hacking tools" that use stock dictionaries. You just said that in your last comment. Please stop bouncing around between threat models. Either you're worried about someone analyzing your passwords - in which case you shouldn't have any kind of pattern, or you're not - in which case even a very simple pattern would do. – Mike Ounsworth Jun 03 '16 at 14:41
  • 1
    @MikeOunsworth, I wouldn't count on appending first and last letter being safe; sure it won't be in the dictionary directly, but I'm pretty sure that would be a fairly common mangling rule for password crackers. More complicated mangling rules *might* work unless a lot of people start using the same or similar rules. – Ben Jun 03 '16 at 17:52
9

This paper suggests that your approach of reusing variants based on a single master password is indeed better than just duplicating passwords. However, as techraf mentions, if you use a simple algorithm, the security benefits may be trivial.

For instance, a common simple algorithm for A is to use a susbet of the domain name in your password (e.g. abcd1234gmail for gmail.com and abcd1234facebook for facebook.com).

Assuming that the algorithm is something that you want to be able to do in your head, what you really want A to accomplish is to give you good diffusion, so that your generated passwords don't share common substrings. This, combined with a fairly long and complex master password, should give you obscure enough variants, so that even if a few passwords are leaked, they look sufficiently different and do not assist password-cracking tools. Pretty soon, I do envisage more studies comparing passwords for the same users across multiple breaches to find out how passwords are commonly varied.

One recommendation I do have is to use a different master password for your most important accounts (just in case). At the end of the day, this is undoubtedly security through obscurity, but isn't that what password selection is all about?

What would truly be valuable is a good way of generating a family of different algorithms {A}, which can be easily computed in your head? Otherwise, you can use a simple program to generate your password using something like hash(master+domain+salt).

Jedi
  • 3,936
  • 2
  • 24
  • 42
  • 1
    I have better algorithms in mind than just appending site name. For example add sitename character wise to password. (`'a' + 'c' = 'd' mod 'z'`) – Andrey Jun 03 '16 at 13:59
  • 2
    Understood. By Kerkchoff's principle, you shouldn't really need your algorithm to be secret. Since this is not practical, what you're really shooting for is that given a small number of your passwords with the corresponding domain name, it should be non-trivial to discover the algorithm `a` . I actually do think yours is a good approach to generating a large number of domain-specific passwords which need to be memorized. I think the general consensus is that the level of security gained is directly related to the strength of your obfuscation algorithm. – Jedi Jun 03 '16 at 19:00
7

You rely on secrecy and complexity of your algorithm. This is a typical example of security through obscurity:

reliance on the secrecy of the design or implementation as the main method of providing security

So you need to take into account its caveats.

It is a good idea as long as you:

  • keep it really secret

    Instead of a secret password, you use a secret algorithm. As it stays in your head, you can assume its secrecy to a certain degree (although this very question already revealed the fact that you might be using one).

    Moving the algorithm outside your head (coding in an app) breaks this condition.

  • don't use too often

    Technically it boils down to encrypting site's URL (cleartext) with:

    • a secret algorithm (simple enough to perform calculations in your head)
    • a fixed password (reused key)

    That doesn't sound secure for encryption and given enough samples it is prone to cryptanalysis.

    But in case of passwords to websites, samples would be rather scarce and on top of that would have to come from a number of compromised sources. It would rather be difficult.

  • make the outcome really random

    Generally if you use a "relatively simple algorithm" you get relatively weak security. Your original algorithm might not be that original and an experienced cryptanalyst might reverse-engineer it even from small number of samples.

    There's a room for improvement here: if you combine your "in-head" algorithm, use it as an input to a hash/key-derivation function and use its output as the password you enter, it drastically increases the security of the scheme.

    However being still in the realm of security through obscurity: what and how you do it must remain undisclosed and even unhinted.

techraf
  • 9,149
  • 11
  • 44
  • 62
  • 1
    Yes I now realise that it definitely based on security through obscurity principle. Yes, experienced cryptanalyst will break it fast. But for that he needs to 1) have access to at least few samples 2) target me personally. I believe that if both conditions are true it is a sign that I have some larger problems with my life. – Andrey Jun 03 '16 at 14:10
  • 1
    ...which is why I said it is a good idea. :) – techraf Jun 03 '16 at 14:21
4

I would argue this is a good security measure that will noticably increase your general security. The reason I say this is because of the typical threat model of stolen passwords. If you are worried about typical hackers/password dumps, they are unlikely to spend the time and effort trying to reverse engineer your password algorithm, when they could be checking the millions of other passwords they have gotten, or trying to hack in to get more.

Essentially, as long as your passwords differ even slightly site to site, you blend in with the people who have password managers. Notably, if you're worried someone is going to try to hack you specifically, this no longer applies, and they'll notice patterns and similarities between passwords they've collected from multiple dumps. It is very difficult, indeed near impossible, to come up with an algorithm you can do in your head that cannot be reversed via a computer from the results.

mklauber
  • 139
  • 4
3

This isn't two factor authentication, it's just one: something you know.

2FA isn't valuable because of the algorithm used to generate the token. It's valuable because that algorithm generates a value which can only be generated by a particular object.

Therefore being able to supply that 2FA token proves you are in possession of that object; in other words: something you have.

Maybe your scheme has security merits, but not because it proxies the secure properties of 2FA. For one it seems like an attacker could steal your password once via phishing and continue logging into that site forever.

thexacre
  • 8,484
  • 3
  • 24
  • 35
3

What you've done is incorporated a scrambling algorithm as part of your overall secret. But scrambling algorithms are not necessarily strong encryption. They're more like puzzles, and they can usually be solved by a dedicated attacker given enough skill, samples, and motivation. (For many examples of people who solve these kinds of problems just for fun, check out puzzles.stackexchange.com.) This leaves all your passwords vulnerable to the weakest sites you visit, not the strongest banking sites.

Example

Let's first assume there are attackers who have the skills. Imagine an unemployed mathematician and puzzle solver, living in a country that's in turmoil, no job prospects, and nothing better to do. Next, let's give him some motivation to attack you - the attacker learns through a boast on facebook that you've got enough money in your retirement account to buy two Lamborghinis. And right now, with this question, you've just told him you use an algorithm to derive all your passwords. He looks up more information about you by following #SOreadytohelp on Twitter. He finds you work at Metacortex, and a bit more googling reveals that Metacortex hosts employee retirement accounts at retirementfundservices.com. So now the only thing standing in the thief's way of your millions is acquiring enough samples to break your algorithm.

I don't know your particular algorithm, but anything simple enough to keep in your head and apply quickly to derive a password is likely not going to survive our attacker if he has three samples; and he'd like a fourth to test his theory. More samples will obviously help him solve the puzzle quicker, with more confidence.

The number of samples needed to crack your algorithm is very important to your security, because your personal security now depends on the total security of all the sites where you use this algorithm, including the weakest of them. But unless you're also a mathematician and puzzle solver, you won't personally know what that number really is. Is it three? Five? If you personally need 20 samples to figure it out, that doesn't guarantee all attackers also need 20 samples to reverse engineer your algorithm - there are many clever people out there.

Assuming the attacker needs only four samples, that means he only has to break into the four weakest sites you visit. Or let's say you previously registered with Adobe, Sony, and Xbox, and those passwords all ended up in pastebin. Now he needs only one more sample. (Let's hope you didn't also sign up on Ashley Madison.) Perhaps the attacker googles you further and discovers you like breeding rabbits as a hobby, and he finds your accounts on rabbit-breeder.org and hobby-rabbit-breeding.com. You can't blame them for not being high security sites, because they have no reason to think they're protecting anything serious like bank accounts. He attacks the first, but they don't have any easy vulnerabilities. He attacks the second with some simple SQL injection, and recovers your password.

Once enough samples have been stolen, the attacker performs the analysis offline, providing no external evidence of success or failure. You simply wake up one morning, check your retirement balance, and discover your money's been transferred to an offshore bank.

Alternatives

You've already considered a purpose built password manager, which is still the best recommendation you're likely to receive.

Consider a hardware tool, like Yubikey or Mooltipass; something you can carry, and that syncs with your online password manager.

You can also successfully use your proposed system by segregating your risk into categories. Low risk sites, like rabbit-breeder.com, get one master password. Medium risk sites, anywhere you use a credit card, get a different master password. High risk sites, anywhere you have banking access, each get their own unique 15+ character password. So now you have to remember only a few passwords, still have good security, and don't need a cumbersome tool.

John Deters
  • 33,897
  • 3
  • 58
  • 112
  • I am not really playing against mathematician who wants my Lamborghinis, I am concerning about keyloggers or getting into large password dumps - being one of the many. – Andrey Jun 04 '16 at 22:28
  • What I'm saying is "do NOT use this scheme to protect passwords that grant access to all your money." Separate your risks into some tiered categories, i.e blogging, shopping, banking, and investments. I'd use this scheme for blogging. I might use it for shopping with a different master password. I would not use this scheme for banking or investments, not even with a different master password. – John Deters Jun 06 '16 at 20:03
3

As I used to use a scheme of this type, I will provide two practical reason to not to use this scheme that I don't see addressed elsewhere.

This scheme will fail if the site you are doing business with changes its name or otherwise gets bought by another company and takes its name. If it is a site you don't visit frequently you might not even realize why your password suddenly does not work.

The second reason to not use this scheme is that every site employs a different criteria for validating passwords.

  • The minimum and maximum length allowed for a password
  • Whether or not a numeric character is required in the password
  • Whether or not a special character is required in the password
  • Whether both uppercase and lowercase characters are required
  • Whether only uppercase and lowercase characters are required
  • Whether non-numeric characters are even allowed (I hate sites that only allow numerics!)
  • What special characters are actually allowed

Even if your scheme can somehow deal with all these variations, there is also the question of how to remember which variation a particular site uses. Usually the site will tell you the requirements when you are creating the password but I don't recall ever seeing one that tells you when you are trying to enter your password.

Michael
  • 409
  • 2
  • 8
  • 16
  • 1
    "This scheme will fail if the site you are doing business with changes its name" -- no problem, they usually have "forget password" link. And I don't think the name is changed every day:) The restrictions on passwords are sometimes annoying... – Ajasja Jun 03 '16 at 21:42
  • Regarding variations - I can use a pattern that will pass most common requirements. For the rest I can keep a list for myself with what modifications are required. As Ajasja said in worst case I could use "forget password". – Andrey Jun 04 '16 at 22:17
1

I'm going to be generous, and assume you can create a secure mangling algorithm which you can do in your head to meet your purposes, which can resist being figured out by a dedicated cracker with good hardware. I sincerely doubt this, but for the sake of argument I'll let it be, and focus on the usability of your scheme.

I've answered a similar question before where my main concern that changing the password becomes prohibitive, because you must change every password, but you already thought of that by remembering a version number for each site, which your mangling algorithm takes into account. Again, I'll assume this is done securely, and isn't just a rolling counter or something, for the sake of argument. So now you have one shared master password to remember, one master algorithm to remember, a username to remember for each site, and a version number for each site.

But some sites have conflicting length requirements for their password. I use some sites with a minimum of 10 character passwords. I use a couple others with a maximum of 8 characters. So your algorithm will need to generate a variable length; you need to remember another piece of information for each site now, the length to input into your algorithm.

More conflicts can exist. Does the site require special characters, or prohibit them? What does the site consider a special character at all? That's another 2 pieces of information to remember for each site. Assuming you have around 100 sites that have a password, now we have:

  • One master password
  • One master algorithm
  • Around 100 version numbers
  • Around 100 lengths
  • Around 100 "require special characters" yes/no inputs
  • Around 100 "allowed characters" inputs
  • Between 1 and 100 usernames

That's 400-500 pieces of information to remember.

Plus, if you ever need to change your master password, or your algorithm (because somebody figured it out somehow, or you accidentally wrote it down and lost it or something) you're still in the situation of being forced to change every single password and remember a new version number for each.

My guess is, you'll start to write these down, or save them in a file. Now you might as well use a password manager.

Using a password manager, you have one piece of information to remember: your master password for your password manager.

If you do things right, you won't lose your password database. For local managers, it's easy to back up one file to multiple locations, and it's strongly encrypted, so you could even upload it to a cloud. For cloud managers, it's already backed up without you doing anything.

If you're worried about access to the database, consider that most popular password managers have apps to use them on most smartphones.

Heck, you could even use the "remember password" feature of Chrome or Firefox, with a master password if you don't want to deal with installing anything. But I think you're making things way to complicated to avoid using something that will make your life easier and more secure.

Ben
  • 3,896
  • 1
  • 10
  • 22
  • 1
    Most of the sites I use don't have crazy requirements and will pass a reasonable password. So specific requirements are edge case for a start. 1 thing I don't like about password managers that if my master password is stolen I am at huge security risk and I might need to do it from public computer. Also if I will have to change all passwords at the same time it will be huge pain. – Andrey Jun 03 '16 at 16:46
  • The exact same drawbacks apply to your scheme. Some password managers like KeePass can take action like using an alternate desktop to enter the master password, or you could always limit yourself to only opening the database on a mobile device and typing individual passwords only on your PC. – Ben Jun 03 '16 at 16:48
  • my schema has at least 1 significant advantage - I never need to enter master password. – Andrey Jun 03 '16 at 17:04
  • 1
    But why is that a significant advantage? If you're worried about key loggers, then you will still need to change any passwords you have when you find it, unless you know exactly which sites you have logged into while infected. So you don't gain in that way. As I pointed out, you could view your passwords on a mobile device, rather than a potentially compromised computer, to avoid exposing your master password. And some password managers take steps to guard against key loggers, such as KeePass's "secure desktop" master password entry feature. So if this is an advantage at all, it's very small. – Ben Jun 03 '16 at 17:43
  • 1
    @Andrey your double-standards are getting a bit frustrating. You won't use a password manager because of keyloggers on public computers, yet you're willing to log into your sensitive accounts on those same computers. Do you not see the contradiction there? I'm starting to wonder if you're actually looking for an answer, or if you're in love with your idea and desperately trying to convince us that it's awesome. – Mike Ounsworth Jun 03 '16 at 19:57
  • @MikeOunsworth I am talking here about moderately sensitive accounts. I don't see any contradiction here - if my master password is stolen all my accounts are almost guaranteed to be compromised it seems to be better than having one account compromised. Basically that is the main problem I was trying to solve. – Andrey Jun 04 '16 at 22:32