开发者

JSON encoded array converted to string when saved as cookie

I have a simple array that I'm trying to JSON encode and set as a cookie. I am using the json2.js script to encode to JSON. I am using the following code to set the cookie:

jQuery(document).ready(function(){
    var ids = ['1', '2'];
    JSON.stringify(ids);
    setCookie(cookieName, ids, 1);
});

function setCookie(name,value,days) {
    if (days) {
        var date = new Date();
        date.setTime(date.getTime()+(days*24*60*60*1000));
        var expires = "; expires="+date.toGMTString();
    }
开发者_Go百科    else var expires = "";
    document.cookie = name+"="+value+expires+"; path=/";
}

After converting the array to JSON, and logging it in console, I get:

["1", "2"]

which is what I would expect. I then read out the cookie with the following function

function getCookie(name) {
    var nameEQ = name + "=";
    var ca = document.cookie.split(';');
    for(var i=0;i < ca.length;i++) {
        var c = ca[i];
        while (c.charAt(0)==' ') c = c.substring(1,c.length);
        if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
    }
    return null;
}

When I read out the cookie and log it in the console, I get:

1,2

suggesting that its a string and no longer a JSON encoded object. I would like to be able to set a cookie an a JSON encoded object, read it out and parse the JSON object, and finally perform operations on the data. My question is thus, how do you send a JSON encoded object to the cookie in such a way that I can parse it as JSON when I read it out?

Thanks as always!


Change this:

JSON.stringify(ids);
setCookie(cookieName, ids, 1);

To this:

var str = JSON.stringify(ids);
setCookie(cookieName, str, 1);


I don't see you actually using the result of the JSON stringification:

jQuery(document).ready(function(){
    var ids = ['1', '2'];
    setCookie(cookieName, JSON.stringify(ids), 1);
});

Try this instead


Don’t use these cookie functions, they are flawed. setCookie fails to encode the name and value properly and getCookie fails for cookies with a common suffix (see my answer to Javascript getCookie functions).

For setCookie I would use this:

function setCookie(name, value, days) {
    var expires = "";
    if (days > 0) {
        var date = new Date();
        date.setTime(date.getTime()+(days*24*60*60*1000));
        expires = "; expires="+date.toGMTString();
    }
    document.cookie = encodeURIComponent(name)+"="+encodeURIComponent(value)+expires+"; path=/";
}
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜