99
Self-documenting Code (lackofimagination.org)
you are viewing a single comment's thread
view the rest of the comments
[-] koper@feddit.nl 38 points 3 weeks ago* (last edited 3 weeks ago)

Why the password.trim()? Silently removing parts of the password can lead to dangerous bugs and tells me the developer didn't peoperly consider how to sanitize input.

I remember once my password for a particular organization had a space at the end. I could log in to all LDAP-connected applications, except for one that would insist my password was wrong. A trim() or similar was likely the culprit.

[-] spechter@lemmy.ml 32 points 3 weeks ago

Another favorite of mine is truncating the password to a certain length w/o informing the user.

[-] NotationalSymmetry@ani.social 16 points 3 weeks ago

Saving the password truncates but validation doesn't. So it just fails every time you try to log in with no explanation. The number of times I have seen this in a production website is too damn high.

[-] nitefox@sh.itjust.works 1 points 3 weeks ago

It also can truncate on the BE side when using the damn varchar

[-] nous@programming.dev 5 points 3 weeks ago

Passwords should be hashed, not stored plain text! Hashes are always the same length so this is an immediate sign they are doing horribly insecure things with your password.

[-] Flipper@feddit.org 11 points 3 weeks ago

The password needs to be 8 letters long and may only contain the alphabet. Also we don't tell you this requirement or tell you that setting the password went wrong. We just lock you out.

[-] Aijan@programming.dev 16 points 3 weeks ago* (last edited 3 weeks ago)

Thanks for the tip. password.trim() can indeed be problematic. I just removed that line.

[-] HamsterRage@lemmy.ca 12 points 3 weeks ago

The reason for leaving in the password.trim() would be one of the few things that I would ever document with a comment.

this post was submitted on 21 Oct 2024
99 points (100.0% liked)

Programming

17424 readers
40 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



founded 1 year ago
MODERATORS