您的位置:首页 > Web前端 > JavaScript

js操作cookies

2008-09-07 16:58 330 查看
问题:

    使得在访问页面的时候能够沿用上次的设置,或者在不同的页面间共享数据。比如用户在访问网站的时候设置了页面字体的大小,那么会希望下次访问的时候仍然能使用同样的设置进行浏览,而不用重复设置。

解决方案:

    在用户浏览页面并进行设置时,将这些设置保存在cookie中,下次访问的时候读取cookie中的设置。

    参考下面的脚本:

    // utility function to retrieve an expiration data in proper format;

    function getExpDate(days, hours, minutes)

    {

        var expDate = new Date();

        if(typeof(days) == "number" && typeof(hours) == "number" && typeof(hours) == "number")

        {

            expDate.setDate(expDate.getDate() + parseInt(days));

            expDate.setHours(expDate.getHours() + parseInt(hours));

            expDate.setMinutes(expDate.getMinutes() + parseInt(minutes));

            return expDate.toGMTString();

        }

    }

    //utility function called by getCookie()

    function getCookieVal(offset)

    {

        var endstr = document.cookie.indexOf(";", offset);

        if(endstr == -1)

        {

            endstr = document.cookie.length;

        }

        return unescape(document.cookie.substring(offset, endstr));

    }

    // primary function to retrieve cookie by name

    function getCookie(name)

    {

        var arg = name + "=";

        var alen = arg.length;

        var clen = document.cookie.length;

        var i = 0;

        while(i < clen)

        {

            var j = i + alen;

            if (document.cookie.substring(i, j) == arg)

            {

                return getCookieVal(j);

            }

            i = document.cookie.indexOf(" ", i) + 1;

            if(i == 0) break;

        }

        return;

    }

    // store cookie value with optional details as needed

    function setCookie(name, value, expires, path, domain, secure)

    {

        document.cookie = name + "=" + escape(value) +

            ((expires) ? "; expires=" + expires : "") +

            ((path) ? "; path=" + path : "") +

            ((domain) ? "; domain=" + domain : "") +

            ((secure) ? "; secure" : "");

    }

    // remove the cookie by setting ancient expiration date

    function deleteCookie(name,path,domain)

    {

        if(getCookie(name))

        {

            document.cookie = name + "=" +

                ((path) ? "; path=" + path : "") +

                ((domain) ? "; domain=" + domain : "") +

                "; expires=Thu, 01-Jan-70 00:00:01 GMT";

        }

    }

    使用getCookie(name)函数来读取cookie中保存的值,参数name为cookie项的名称。如果该cookie项不存在则返回一个空字符串。

    使用setCookie()函数来保存cookie项的值,其中第一、二两个参数分别为cookie项的名称和值。如果想为其设置一个过期时间,那么就需要设置第三个参数,这里需要通过getExpDate()获得一个正确格式的参数。

    最后,使用deleteCookie()来删除一个已存在的cookie项,实际上是通过让该项过期。

    cookie将数据保存在客户端。页面的脚本只能读取所在域和服务器的cookie值,如果域内有多个服务器,那么需要设置第五个参数,以指定服务器。浏览器的容量一般限定为每服务器20个name/value对,每个cookie项不超过4000个字符,更现实点,单个cookie项应少于2000字符,也就是说不要用cookie在客户端保存大容量数据。

    不同的浏览器保存cookie的方式也有所不同。IE为每个域的cookie建立一个文本文件,而Netscape则将所有的cookie存储在同一个文本文件中。

    注意:cookie存放在客户端,所以会受到浏览器设置的影响,比如用户可能会禁用cookie。要检测浏览器是否支持cookie,使用属性navigator.cookieEnabled来判断。

//**********************************

//js操作cookies

//

//**********************************

function $(_o){return document.getElementById(_o)}

function SetCookie(name,value)//两个参数,一个是cookie的名子,一个是值

{

    var Days = 1; //此 cookie 将被保存 1 天

    var exp = new Date();    //new Date("December 31, 9998");

    exp.setTime(exp.getTime() + Days*24*60*60*1000);

    document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();

}

function getCookie(name)//取cookies函数       

{

    var arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"));

     if(arr != null) return unescape(arr[2]); return null;

}

function delCookie(name)//删除cookie

{

    var exp = new Date();

    exp.setTime(exp.getTime() - 1);

    var cval=getCookie(name);

    if(cval!=null) document.cookie= name + "="+cval+";expires="+exp.toGMTString();

}

//**********************************

//javascript加密解密

//

//**********************************

function ucode(str){

        ;

        var t="";

        var a,a1,a2,a3;

        var md5="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789fgklm"

        var b=md5.split("");

        for(var x=0;x
        a=str.charCodeAt(x);

        a1=a%41;

        a=(a-a1)/41;

        a2=a%41;

        a=(a-a2)/41;

        a3=a%41;

        t+=b[a3]+b[a2]+b[a1]}a="z";

        for(var x=0;x
        if(t.charAt(x)!="A"){return t}

        a+=t.substr(x+1,2)

        }return a

        }

        function decode(str){

        ;

        var md5="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789fgklm"

        var a1,a2,a3,b=md5,d=0,t,a;

        if(str.charAt(0)=="z"){

        t=new Array(Math.floor((str.length-1)/2))

        a=t.length;for(var x=0;x
        d++;a3=b.indexOf(str.charAt(d))

        t[x]=a2*41+a3}};else{t=new Array(Math.floor(str.length/3))

        a=t.length;for(var x=0;x
        d++;a2=b.indexOf(str.charAt(d))

        d++;a3=b.indexOf(str.charAt(d))

        d++;t[x]=a1*1681+a2*41+a3}}

        a=eval("String.fromCharCode("+t.join(’,’)+")");return a}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: