在ASP.NET中的Response.Redirect中传递cookie

前端之家收集整理的这篇文章主要介绍了在ASP.NET中的Response.Redirect中传递cookie前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在将ASP.NET中的cookie传递给新URL时遇到问题.我像这样在响应中添加cookie:
  1. Response.Cookies.Add(new HttpCookie("Username",Username.Text));

然后我发出重定向

的Response.Redirect(RETURNURL);

在我重定向到的新页面上,cookie集合为空.我尝试像这样检索一个cookie:

Request.Cookies时[ “用户名”]值.

任何人都可以想到为什么没有通过cookie?

编辑:

进一步的信息我忘了添加 – 在同一个浏览器会话中的第二次尝试,cookie通过重定向正确传递.

编辑#2:我发现如果我在重定向URL中使用“localhost”而不是实际的域名,那么首次登录时会正确传递cookie.因此,只有当重定向URL是实际的域名时才会起作用.奇怪.

解决方法

  1. protected void Page_Load(object sender,EventArgs e)
  2. {
  3. if (!Page.IsPostBack)
  4. {
  5. if (Request.QueryString["AcceptsCookies"] == null)
  6. {
  7. Response.Cookies["TestCookie"].Value = "ok";
  8. Response.Cookies["TestCookie"].Expires =
  9. DateTime.Now.AddMinutes(1);
  10. Response.Redirect("TestForCookies.aspx?redirect=" +
  11. Server.UrlEncode(Request.Url.ToString()));
  12. }
  13. else
  14. {
  15. Label1.Text = "Accept cookies = " +
  16. Server.UrlEncode(
  17. Request.QueryString["AcceptsCookies"]);
  18. }
  19. }
  20. }

This link将帮助您了解C#中的读写cookie.

此外,如果您熟悉VB而不是C#,@L_301_1@将非常有用.

猜你在找的asp.Net相关文章