MySQL how to make value expire?

后端 未结 3 1109
无人共我
无人共我 2021-01-07 06:24

So I\'m currently designing a Forgot Password feature for a website. Basically, when the user clicks forgot password it sends them an email with a reset token. I want the re

相关标签:
3条回答
  • 2021-01-07 07:00

    I'd use MySQL Events for that:

    CREATE EVENT IF NOT EXISTS `dbName`.`eventName`
    ON SCHEDULE
    EVERY 1 DAY // or 1 HOUR
    COMMENT 'Description'
    DO
    BEGIN
    
    DELETE FROM `dbName`.`TableName` WHERE `expireDateCol` < NOW();
    
    END
    

    and enable the MySQL Event Scheduler , see original source.

    source: https://stackoverflow.com/a/24568566/2069181

    0 讨论(0)
  • 2021-01-07 07:14

    In addition to your column resetkey you will also have a column resetDeadline. When they get a reset token you will set the deadline for some datetime in the future. When they try to log in with the resetkey always check that NOW() < resetDeadline. If it is then check the resetkey and allow the reset. If it isn't then don't bother checking the resetkey - just don't allow it.

    0 讨论(0)
  • 2021-01-07 07:15

    Next to your resetkey column place a DATETIME column called, maybe, expires.

    Then, whenever you insert a new reset key, also insert a value into expires:

    INSERT INTO forgot (resetkey, expires) VALUES (whatever, NOW() + INTERVAL 48 HOUR)
    

    Right before you read any reset key from the table, do this:

    DELETE FROM forgot WHERE expires < NOW()
    

    Then you'll never see an expired key; they'll always get wiped out if they have expired.

    Now, you could choose to do something with looking up a user-furnished reset key. If it's expired you could announce that to the user: "Your reset key has expired." But that's a bad idea ... for security's sake you shouldn't help users understand why a security token like a reset key is invalid. You should just say "that reset key is not correct."

    Does this leave open the possibility that some rows containing expired token will persist in the table? Yes. But it won't be possible for your app to actually read them and used them if you follow the procedure of wiping out the expired ones before using any tokens. If you had a reason to avoid keeping expired tokens in the table even though they're useless, you could set up an EVENT or some other kind of regularly scheduled job to run the DELETE statement I mentioned.

    0 讨论(0)
提交回复
热议问题