Cookie 是一種在客戶端存儲數據的技術,它可以被服務器讀取,這樣便可以實現信息交互。那么,它是否可以存儲 JSON 對象呢?
// 以下為設置 cookie 中存儲 JSON 的示例 // 假設數據為 JSON 格式的對象 const data = { name: 'Cookie', value: 'Hello World' }; // 將對象轉換成 JSON 字符串 const jsonData = JSON.stringify(data); // 在 cookie 中存儲 JSON 字符串 document.cookie = `json=${jsonData}`;
可以看到,在此示例中,我們可以使用 JSON.stringify() 把一個 JavaScript 對象轉換成 JSON 字符串,然后將其存儲在 cookie 中,以便下次會話時服務器將其讀取。
// 以下是獲取 cookie 中存儲的 JSON 的示例 // 獲取所有 cookie const cookies = document.cookie.split(';'); // 遍歷每一個 cookie for (let i = 0; i< cookies.length; i++) { // 找到名為 json 的 cookie if (cookies[i].trim().startsWith('json=')) { // 獲取整個 cookie 字符串 const cookie = cookies[i].trim(); // 截取出 JSON 字符串 const jsonString = cookie.substring(5); // 將字符串轉換成 JSON 對象 const jsonData = JSON.parse(jsonString); // 使用 JSON console.log(jsonData); } }
在此示例中,我們首先使用 document.cookie 獲取到所有的 cookie,然后遍歷獲取到的 cookie,找到名為 ‘json’ 的 cookie,再使用 substring() 方法獲取到 JSON 字符串,并使用 JSON.parse() 方法將其轉換成 JavaScript 對象。
總的來說,使用 cookie 存儲 JSON 對象是可行的,但是這樣做存在許多缺點,例如:cookie 有大小限制,不同瀏覽器間 cookie 存儲方式不同,而且 cookie 存儲在客戶端容易被侵犯,因此,生產環境中建議盡量避免使用 cookie 存儲大量數據。