JavaScript 设置和获取 cookie?

标签 javascript html cookies

我有一个保存cookies的功能

    cookievalue= escape(document.passwordCheck.oldPassword.value) + ";";
    document.cookie="oldCookie=" + cookievalue
    cookievalue= escape(document.passwordCheck.oldPassword.value) + ";";
    document.cookie="newCookie=" + cookievalue

如何检索 oldCookie 和 newCookie 的数据?

最佳答案

W3CSchool 的功能有问题。如果有多个具有相同后缀的 cookie,它将失败,例如:

ffoo=bar; foo=baz

当您搜索 foo 时,它将返回 ffoo 而不是 foo 的值。

现在我要做的是:首先,您需要了解 cookie 传输的语法。 Netscape 的原始规范(只有副本可用,如 this one at haxx.se )使用分号分隔多个 cookie,而每个名称/值对具有以下语法:

NAME=VALUE
This string is a sequence of characters excluding semi-colon, comma and white space. If there is a need to place such data in the name or value, some encoding method such as URL style %XX encoding is recommended, though no encoding is defined or required.

所以在分号或逗号处拆分 document.cookie 字符串是一个可行的选择。

除此之外,RFC 2109还指定 cookie 由分号或逗号分隔:

cookie          =       "Cookie:" cookie-version
                        1*((";" | ",") cookie-value)
cookie-value    =       NAME "=" VALUE [";" path] [";" domain]
cookie-version  =       "$Version" "=" value
NAME            =       attr
VALUE           =       value
path            =       "$Path" "=" value
domain          =       "$Domain" "=" value

虽然两者都是允许的,但逗号是首选,因为它们是 HTTP 中列表项的默认分隔符。

Note: For backward compatibility, the separator in the Cookie header is semi-colon (;) everywhere. A server should also accept comma (,) as the separator between cookie-values for future compatibility.

此外,名称/值对还有一些进一步的限制,因为 VALUE 也可以是 RFC 2616 中指定的带引号的字符串:

attr        =     token
value       =     token | quoted-string

所以这两个cookie版本需要分开处理:

if (typeof String.prototype.trimLeft !== "function") {
    String.prototype.trimLeft = function() {
        return this.replace(/^\s+/, "");
    };
}
if (typeof String.prototype.trimRight !== "function") {
    String.prototype.trimRight = function() {
        return this.replace(/\s+$/, "");
    };
}
if (typeof Array.prototype.map !== "function") {
    Array.prototype.map = function(callback, thisArg) {
        for (var i=0, n=this.length, a=[]; i<n; i++) {
            if (i in this) a[i] = callback.call(thisArg, this[i]);
        }
        return a;
    };
}
function getCookies() {
    var c = document.cookie, v = 0, cookies = {};
    if (document.cookie.match(/^\s*\$Version=(?:"1"|1);\s*(.*)/)) {
        c = RegExp.$1;
        v = 1;
    }
    if (v === 0) {
        c.split(/[,;]/).map(function(cookie) {
            var parts = cookie.split(/=/, 2),
                name = decodeURIComponent(parts[0].trimLeft()),
                value = parts.length > 1 ? decodeURIComponent(parts[1].trimRight()) : null;
            cookies[name] = value;
        });
    } else {
        c.match(/(?:^|\s+)([!#$%&'*+\-.0-9A-Z^`a-z|~]+)=([!#$%&'*+\-.0-9A-Z^`a-z|~]*|"(?:[\x20-\x7E\x80\xFF]|\\[\x00-\x7F])*")(?=\s*[,;]|$)/g).map(function($0, $1) {
            var name = $0,
                value = $1.charAt(0) === '"'
                          ? $1.substr(1, -1).replace(/\\(.)/g, "$1")
                          : $1;
            cookies[name] = value;
        });
    }
    return cookies;
}
function getCookie(name) {
    return getCookies()[name];
}

来源:https://stackoverflow.com/a/4004010

关于JavaScript 设置和获取 cookie?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11251791/

相关文章:

jquery Cookie 设置并获取 div 的扩展状态

jquery - 刷新时保留复选框的值

Javascript - 解析长 GET 请求 JSON

javascript - Nodejs - 加载一次模块并在许多不同的文件中使用

javascript - 如何使用 JQuery 选择在页面加载时显示哪个 CSS 类?

javascript - AngularJS - 如何检查指令内的复选框?

ruby-on-rails - Restful 认证 : Allow logins from multiple computers?

javascript - Send_keys 函数确实按 Selenium python 中的预期工作

javascript - ASP NET Core - 以编程方式清除 ResponseCache

javascript - 列表框(表格)中的大量数据