Created
July 20, 2011 23:07
-
-
Save anhang/1096149 to your computer and use it in GitHub Desktop.
HTML5 Local Storage with Expiration
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
AZHU.storage = { | |
save : function(key, jsonData, expirationMin){ | |
if (!Modernizr.localstorage){return false;} | |
var expirationMS = expirationMin * 60 * 1000; | |
var record = {value: JSON.stringify(jsonData), timestamp: new Date().getTime() + expirationMS} | |
localStorage.setItem(key, JSON.stringify(record)); | |
return jsonData; | |
}, | |
load : function(key){ | |
if (!Modernizr.localstorage){return false;} | |
var record = JSON.parse(localStorage.getItem(key)); | |
if (!record){return false;} | |
return (new Date().getTime() < record.timestamp && JSON.parse(record.value)); | |
} | |
} |
👍
This would just not load the storage, while it is still available in the browser for other scripts.
Maybe a safer solution could be to encrypt the local storage and store the key in an cookie with expiry date?
7 years and still very helpful. Thank you!
Good contributions endure over time. Thank you.
This code has one problem (as I see!?), it didn't delete the expired cache.
https://github.com/liesislukas/localstorage-ttl/blob/master/index.js
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
👍