如何使用 Ajax/jQuery 设置 cookie?
how can set cookie with Ajax/jQuery?
我有 ajax 功能如下:
$.ajax({
url:"cookie.php",
type: 'post',
data: {'ok': val},
success:function(data) {
alert(data);
}
});
我的 setcookie cookie.php 是:
$name = "mySite";
$value = "whosebug.com";
setcookie($name, $value, time() + (86400 * 30), "/");
echo $name."=".$value;
我的 ajax 函数 mySite=whosebug.com
显示在我的页面中,但浏览器中未设置 cookie。为什么?
Cookie 是使用 HTTP Set-Cookie
header 设置的,在页面首次加载时在 HTTP 响应中发送。
这 header 指示浏览器存储 cookie 并在以后的请求中将其发送回服务器。
当您使用 ajax 设置 cookie 时,浏览器不会重新加载当前页面,也不会发送新的 header。
相反,一个新的请求在后台发送 XMLHttpRequest
,并且 cookie 永远不会添加到当前页面 headers,因为该页面更新重新加载并接收包含 cookie 的 header .
您必须重新加载页面并获取一组新的 headers 才能看到 PHP 中添加的新 cookie。
在 javascript 中还有设置 cookie 的选项,然后它们将立即在浏览器中可见。
document.cookie="mySite=whosebug.com; expires=Thu, 18 Dec 2015 12:00:00 UTC; path=/";
我有 ajax 功能如下:
$.ajax({
url:"cookie.php",
type: 'post',
data: {'ok': val},
success:function(data) {
alert(data);
}
});
我的 setcookie cookie.php 是:
$name = "mySite";
$value = "whosebug.com";
setcookie($name, $value, time() + (86400 * 30), "/");
echo $name."=".$value;
我的 ajax 函数 mySite=whosebug.com
显示在我的页面中,但浏览器中未设置 cookie。为什么?
Cookie 是使用 HTTP Set-Cookie
header 设置的,在页面首次加载时在 HTTP 响应中发送。
这 header 指示浏览器存储 cookie 并在以后的请求中将其发送回服务器。
当您使用 ajax 设置 cookie 时,浏览器不会重新加载当前页面,也不会发送新的 header。
相反,一个新的请求在后台发送 XMLHttpRequest
,并且 cookie 永远不会添加到当前页面 headers,因为该页面更新重新加载并接收包含 cookie 的 header .
您必须重新加载页面并获取一组新的 headers 才能看到 PHP 中添加的新 cookie。
在 javascript 中还有设置 cookie 的选项,然后它们将立即在浏览器中可见。
document.cookie="mySite=whosebug.com; expires=Thu, 18 Dec 2015 12:00:00 UTC; path=/";