Web Application - Storing a Password

前端 未结 2 656
抹茶落季
抹茶落季 2021-02-03 12:48

Have I missed anything? Are there any additional steps storing passwords to the DB?

Storing the Password:
    After as much re

2条回答
  •  北恋
    北恋 (楼主)
    2021-02-03 13:32

    Nice work! Looks very complete to me.

    Only suggestions I would have are:

    Rotate the service salt.

    Design a method to periodically rotate the service-wide salt, and exercise it regularly.

    For example, after generating a new service salt, use it for all new accounts & any password changes. When an existing user tries to log in, authenticate them with the old service salt. If successful, update their hash with the new service salt (and optionally a new user-specific salt). For users who don't log in for 'some time', randomly generate a new password on their behalf. This will 'keep up' security for users who've abandoned your site, forcing those that return to use the password reset facilities. ('some time' = whatever period you're comfortable with).

    Don't hard-code your service salt.

    Don't allow a LFI attack to compromise your service salt. Feed the service-salt to your application at start up, and keep it in memory. To compromise the service salt, an attacker would need to be able to execute code to read the salt from memory. If an attacker can do that, you're pretty well hosed anyway. =)

    Don't reuse a users salt.

    Look for opportunities to give users new salts. User changes his password? Generate a new random salt. This further hampers brute forcing your server-wide salt should an attacker be able to obtain his hash whenever he feels like it. Couple this with regularly rotating your service-salt, and I'd wager you've got a strong deterrent against brute-forcing.

    (Marking this as a community wiki should others have additional ideas).

提交回复
热议问题