cookie和会话在该代码中的工作方式

how cookie and session work in this code?

本文关键字:工作 方式 代码 会话 cookie      更新时间:2023-09-26

几天前,我问我的朋友关于我网站的会话以及如何使其正确工作,他在这里给了我这个代码。。。

var $ = jQuery.noConflict();
$(document).ready(function () {
    /*$("a").each(function() {
    $(this).attr("hideFocus", "true");
    });*/
    jQuery.cookie = function (name, value, options) {
        if (typeof value != 'undefined') {
            options = options || {};
            if (value === null) {
                value = '';
                options.expires = -1;
            }
            var expires = '';
            if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) {
                var date;
                if (typeof options.expires == 'number') {
                    date = new Date();
                    date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));
                } else {
                    date = options.expires;
                }
                expires = '; expires=' + date.toUTCString();
            }
            var path = options.path ? '; path=' + (options.path) : '';
            var domain = options.domain ? '; domain=' + (options.domain) : '';
            var secure = options.secure ? '; secure' : '';
            document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join('');
        } else {
            var cookieValue = null;
            if (document.cookie && document.cookie != '') {
                var cookies = document.cookie.split(';');
                for (var i = 0; i < cookies.length; i++) {
                    var cookie = jQuery.trim(cookies[i]);
                    if (cookie.substring(0, name.length + 1) == (name + '=')) {
                        cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
                        break;
                    }
                }
            }
            return cookieValue;
        }
    };

我注意到代码中的过期,但我不知道它在程序中到底在做什么?如果可能的话,我只想有人简单地解释一下上面的代码。谢谢

cookie是用户浏览网站时从网站发送并存储在用户web浏览器中的一小段数据。

有一些参数可以调节浏览器中cookie的行为

  1. cookie的名称
  2. cookie的值
  3. cookie的到期时间(使用格林尼治标准时间)
  4. cookie适用的路径
  5. cookie适用的域
  6. 需要安全连接才能使用cookie

在像PHP这样的服务器端语言的会话组合中,它们可以用来存储用户的状态。比如用户登录或注销、权限等。

上面的代码设置或获取存储在用户浏览器中的cookie的值。

参考:

  1. http://en.wikipedia.org/wiki/HTTP_cookie
  2. http://en.wikipedia.org/wiki/Session_(计算机科学)