修改HttpHandler中的Cookie值
|
我有一个cookie,可以用来保留用户的用户名,但是我很难用新值替换它。根据MSDN,我应该能够简单地覆盖该值,但是它没有起作用。我正在处理程序中执行登录逻辑,并将用户成功传递到新网页。
public void ProcessRequest(HttpContext context)
{
User user = User.FindByUsernameAndPassword(
context.Request.Form[\"username\"],
context.Request.Form[\"password\"]);
context.Response.Cookies[\"user_id\"].Value = user.ID.ToString();
context.Response.Redirect(\"/profile\", true);
}
第一次登录时效果很好,但是如果我尝试通过使用新的用户ID击中处理程序来覆盖当前的cookie,它不会更改cookie值,因此我将继续以原本的用户身份登录当我打它。
其他页面使用cookie登录,但是由于用户ID不变,因此不会更改登录的用户。
public User User { get; set; }
public override void Page_Load()
{
this.User = User.Find(int.Parse(Request.Cookies[\"user_id\"].Value));
}
没有找到相关结果
已邀请:
2 个回复
诞胃
揽芳僵迷仇
我同意关于添加.Value属性的第一篇文章,然后也可以添加.Expires,看看会发生什么。