Are there any benefits of CHAR over VARCHAR for storing passwords?
I have hunted high and low but can't find anything on this.
I ask because I have been told to use CHAR for passwords and am intrigued as to why.
Are there any benefits of CHAR over VARCHAR for storing passwords?
I have hunted high and low but can't find anything on this.
I ask because I have been told to use CHAR for passwords and am intrigued as to why.
Do your passwords have a max length constraint? If they do, you should have no need for
varchar
.In any case, if you are storing passwords, you should be hashing them and storing the hash. Many hashing algorithms hash to a fixed size so I don't think char should be an issue here. Just allocate the appropriate amount of characters.
Whatever you do, make sure you hash them!
There is no difference in security. The difference is in the storage mechanism.
From the MySQL manual:
So you can see that
VARCHAR
is beneficial if the length of the string that you are storing is variable. The reason whyCHAR
is often used for password fields is because the output of hashing algorithms is consistent regardless of the length of input. Since you are storing a hash of the user's password, and not the password itself, the field length will be consistent.leeor is correct in advising you to hash passwords. PHP The Right Way is a good resource for best practices in that regard.