关于后端cookie的问题,设置cookie后,可以立即得到,但重新发出请求后,cookie就获取不到了

lingchenaishuiruo 2017-10-29 09:11:59
关于后端cookie的问题,设置cookie后,可以立即得到,但重新发出请求后,cookie就获取不到了,设置了cookie的过期时间的。
在:ashx一般处理程序中有一个检查cookie的函数如下:
private void CheckCartCookie(HttpContext context)
{
int bookId = Convert.ToInt32(context.Request["bookId"]);
int bookAmount = Convert.ToInt32(context.Request["amount"]);
string bookName = context.Request["bookName"];
string get_value = Common.CookieHelper.GetCookieValue("cart");
if (Common.CookieHelper.GetCookieValue("cart")==string.Empty)//缓存中未有“cart”
{
Model.CookieCart cookieCart = new Model.CookieCart
{
BookId = bookId,
Amount = bookAmount,
BookName = bookName
};
list.Add(cookieCart);
Common.CookieHelper.SetCookie("cart",Common.JsonHelper.ObjectToJson(list), DateTime.Now.AddDays(7));
string getvalue = Common.CookieHelper.GetCookieValue("cart");
}
刚设置完cookie后,cookie有值,能够发现getvalue 是存的正确的cookie,但重新发出请求后,就得不到cookie的值,因为得不到
get_value的值,这是为什么?求大佬解答

cookie我封装了一个类CookieHelper代码如下:
public class CookieHelper
{
/// <summary>
/// 清除指定Cookie
/// </summary>
/// <param name="cookiename">cookiename</param>
public static void ClearCookie(string cookiename)
{
HttpCookie cookie = HttpContext.Current.Request.Cookies[cookiename];
if (cookie != null)
{
cookie.Expires = DateTime.Now.AddYears(-3);
HttpContext.Current.Response.Cookies.Add(cookie);

}
}
/// <summary>
/// 获取指定Cookie值
/// </summary>
/// <param name="cookiename">cookiename</param>
/// <returns></returns>
public static string GetCookieValue(string cookiename)
{
HttpCookie cookie = HttpContext.Current.Request.Cookies[cookiename];
string str = string.Empty;
if (cookie != null)
{
str = HttpUtility.UrlDecode(cookie.Value);
}
return str;
}
/// <summary>
/// 添加一个Cookie(24小时过期)
/// </summary>
/// <param name="cookiename"></param>
/// <param name="cookievalue"></param>
public static void SetCookie(string cookiename, string cookievalue)
{
SetCookie(cookiename, HttpUtility.UrlEncode(cookievalue), DateTime.Now.AddDays(1.0));
}
/// <summary>
/// 添加一个Cookie
/// </summary>
/// <param name="cookiename">cookie名</param>
/// <param name="cookievalue">cookie值</param>
/// <param name="expires">过期时间 DateTime</param>
public static void SetCookie(string cookiename, string cookievalue, DateTime expires)
{
HttpCookie cookie = new HttpCookie(cookiename)
{
Value = HttpUtility.UrlEncode(cookievalue),
Expires = expires
};
HttpContext.Current.Response.Cookies.Add(cookie);
}
}
...全文
1795 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
lingchenaishuiruo 2017-10-30
  • 打赏
  • 举报
回复
求支援啊
lingchenaishuiruo 2017-10-30
  • 打赏
  • 举报
回复
Domain我没设值,那就是默认域名嘛。我这里只有一个域名,path我设置为“/”就是同一域名下的所用路径都能访问是不是?但重新发出请求后依然没有相应cookie的值,这到底是为什么呢?
lingchenaishuiruo 2017-10-30
  • 打赏
  • 举报
回复
谢谢提醒,我去查了一下,大概懂了点,可以确定的是作用域为默认主机,我去改下作用路径看能行不、
丰云 2017-10-30
  • 打赏
  • 举报
回复
cookie不光是有过期时间,还有作用域和作用路径的属性
lingchenaishuiruo 2017-10-30
  • 打赏
  • 举报
回复
我用的是键的key的名字,没有用过Name,是根据key取value吧
lingchenaishuiruo 2017-10-30
  • 打赏
  • 举报
回复
我一个键对应一个值,这2个应该没得差别吧,不太懂
丰云 2017-10-30
  • 打赏
  • 举报
回复
你是不是把cookie的名字和键值对key、value里面的key搞混了??
  • 打赏
  • 举报
回复
在浏览器看下你的请求、cookie
资源下载链接为: https://pan.quark.cn/s/9648a1f24758 在开发过程中,主要负责后端开发,使用的是 Spring Boot 2.0,后端服务部署在 IP 地址为 192.168.1.217 的服务器上,前端则使用 Vue 框架,部署在 IP 地址为 192.168.1.205 的服务器上。在登录功能实现时,登录成功后会将用户信息存储到 session 中,后续请求需要从 session 中取出用户信息进行验证。然而,后续请求取出的用户信息始终为 null,导致无法正常进行用户验证。 经过排查,首先发现 sessionID 不一致,这表明每次请求都被视为新的会话,因此无法从 session 中获取到用户信息。进一步检查发现,浏览器无法自动保存 cookie,尽管服务器响应中包含了 Set-Cookie,但浏览器并未将其保存下来。经过分析,问题出在跨域上,由于前后端部署在不同的 IP 地址上,属于跨域请求,导致浏览器无法保存服务器响应中的 Set-Cookie,即使保存了,由于域名不同,浏览器也不会将其携带到后续请求中。 为了解决这个问题,需要在后端添加一个过滤器。因为前后端分离,无法在每个接口中单独处理跨域问题,所以通过全局过滤器来解决。过滤器的作用是在每次请求到达后端之前,先处理跨域问题,允许前端域名对应的请求访问后端接口,并确保 cookie 能够正常保存和携带。

62,243

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧