Ich habe ein Hilfsobjekt zum Speichern von JSON im URL-Hash erstellt. Siehe das Projekt hier auf GitHub :
Dies ist nützlich für persistente Seiteneinstellungen ohne einen Cookie. Funktioniert ziemlich gut und ich mag es.
Was sind Gedanken für und gegen diesen Ansatz? Ich habe gelesen, Sicherheit könnte sein. Ist es wirklich, wenn Sie json2.js oder das native JSON-Objekt in neueren Browsern verwenden?
rison scheint kompakter und effizienter zu sein. Zumal viele in JSON verwendete Zeichen nicht URI-sicher sind.
Außerdem ist es selten sinnvoll, vertrauliche Informationen (dh die meisten davon) in alles aufzunehmen, was zwischen Server und Client hin und her geht. Aus diesem Grund speichern die meisten Sitzungsschemata nur eine Sitzungs-ID in einem Cookie und nicht alle Informationen. In diesem Fall ist das Hinzufügen der ID zur URL nicht schwieriger als die Verwendung des Cookies. In der Tat war das der Standardmodus für PHP-Sitzungen in früheren Zeiten, als Cookies ein fortgeschrittenes Feature einiger Browser waren.
In welchem Teil der URL speichern Sie es? Die #fragment
oder die ?query
?
Wenn es die Abfrage ist ... nicht .
Wie diese:
Wenn der Status in einem einzelnen Browser verwaltet werden soll und nicht mit anderen Benutzern oder Browsern geteilt werden soll, kann es besser sein, den Status in localStorage beizubehalten. Ein Framework wie amplify.store unterstützt die meisten Browser, die Ihnen begegnen werden (IE 5+, Firefox 2+, Safari 4+, Chrome, Opera 10.5+, iPhone 2+, Android 2+): < a href="http://amplifyjs.com/api/store/"> Ссылка
Es ist viel einfacher zu benutzen als ein Cookie, viel mächtiger und hat nicht die potentiellen Bedenken, die @ Javier erwähnt.
Wenn Sie möchten, dass der Status über Browser (und / oder Benutzer) verwaltet wird, ist die URL Ihre bessere Wahl, und in diesem Fall würde ich auch riskieren.
Tags und Links javascript json