this post was submitted on 26 May 2025
578 points (96.3% liked)

Cybersecurity - Memes

3491 readers
1 users here now

Only the hottest memes in Cybersecurity

founded 2 years ago
MODERATORS
 
you are viewing a single comment's thread
view the rest of the comments
[–] anguo@lemmy.ca 54 points 5 months ago (4 children)

What gets me is the "password is too similar to old password".

How do they know? Are they storing them in plain text? I would imagine the hash would change drastically even if I change a single character, no?

[–] owenfromcanada@lemmy.ca 28 points 5 months ago (4 children)

I can imagine one legitimate case: when you create a password, they save the hash for the full password as well as the hash for the password without the last character. So if you attempt to change only the last character, they can detect it. They'd need to salt the two separately though.

In theory, they could do the same for every character, but they'd have to save 20+ combinations for that (plus all the salt), so I doubt anyone is doing that.

[–] Biyoo@lemmy.blahaj.zone 6 points 5 months ago* (last edited 5 months ago)

No need to store it, you can do the opposite, create 20 variations of the new password, hash them, check if any match with the old password.

Edit : nevermind, it would only work if they added data instead of editing it.

[–] frezik@midwest.social 6 points 5 months ago

The strongly recommended hashing algorithms are slow on purpose, and often use up a lot of RAM, too. Multiplying the number of hashes you would need would multiply CPU/memory load for every new password.

[–] JcbAzPx@lemmy.world 3 points 5 months ago (1 children)

Yeah, but 99.999...% of the time, they're just storing plaintext.

[–] owenfromcanada@lemmy.ca 2 points 5 months ago

I dunno about that, probably more like 99.98%.

[–] Hasherm0n@lemmy.world 2 points 5 months ago* (last edited 5 months ago) (1 children)

Cryptographic hashes don't work like that. One of the defined properties of a strong cryptographic hash is that changing even one bit on the input results in about 50% of the bits of the output getting flipped in a non predictable way. There's simply no way to tell from looking at two cryptographic hashes how similar their inputs are. If there were, that would weaken the security significantly.

[–] CookieOfFortune@lemmy.world 12 points 5 months ago (1 children)

Why wouldn’t it work?

You’re removing the last character before hashing, so the removed character won’t affect the hash value.

[–] goodeye8@fedia.io 2 points 5 months ago (2 children)

Because

they save the hash for the full password as well as the hash for the password without the last character. So if you attempt to change only the last character, they can detect it.

is not how hashing works. You can't create a subset hash to compare against the set hash.

Let's say my password is "ILoveUsingSimplePasswords1".

You remove the last character and get "ILoveUsingSimplePasswords".

And then I change the password to "ILoveUsingSimplePasswords2".

Now here are those 3 "passwords" hashed.

  • 5c30739dfd7a5df387f9a3e6c08a026831314e8cc8df4f18e3c2a7baddf30bb2
  • a78cb4f0ddf5513862e97e20fe8f331d08bbb5aacf0ac14c0b6a0f1b036a7b6b
  • 9385bd96fb795abd7204d27990e8c7b2bf929bac772b6f8e3b875e8a313be5cb

Can you tell which of the 3 is "ILoveUsingSimplePasswords" and can you identify where I've added 1 or 2 to the end? You can't because it's not how hashing works.

[–] bane_killgrind@slrpnk.net 20 points 5 months ago (1 children)

This is not what he meant. If the password is xyz he stores the hash (f*) for xyz and xy. When you change your password to xyb, it compares fxyz to the first saved hash and a truncated fxy to the second saved hash, flagging if you've only changed the last character. The mask length could be arbitrary and there can be many saved hashes at the expense of making password resets slow.

[–] goodeye8@fedia.io 12 points 5 months ago (1 children)

I get it now. They're comparing only trunks because the hash of the trunk wouldn't change.

[–] owenfromcanada@lemmy.ca 4 points 5 months ago

Yep, that's what I meant. Pretty sure my company does this, because they can detect this, and I know enough of our IT to believe they're not storing passwords in plaintext.

[–] CookieOfFortune@lemmy.world 6 points 5 months ago

You didn’t remove the last character of “passwords2”. When you remove the last character, that becomes “passwords” and therefore has the same hash as “passwords1”[:-1]

[–] Agent641@lemmy.world 15 points 5 months ago (1 children)

They pay a kid in Bangladesh 14c an hour to visually compare the new password against the old one.

[–] whoisearth@lemmy.ca 1 points 5 months ago (1 children)
[–] papertowels@mander.xyz 1 points 5 months ago

Just a dude they call al, short for Allen

[–] traches@sh.itjust.works 13 points 5 months ago

Usually you have to enter your old password on the same form in order to set a new one.

Alternatively they could run a bunch of common substitutions on the new password, hash, and check if anything matches the old hash.

[–] JPAKx4@lemmy.blahaj.zone 11 points 5 months ago

I mean they could technically check common password modifications and test all of those hashes against your old hash to see, if they're storing plaintext and you should delete your account immediately.

My guess is the latter is correct