我使用以下代码创建我自己的身份验证票证:
string formsCookieStr = string.Empty; FormsAuthenticationTicket ticket = new FormsAuthenticationTicket( 1,// version username,// user name DateTime.Now,// issue time DateTime.Now.AddMinutes(30),// expires false,// Persistence userRoleData // user data ); formsCookieStr = FormsAuthentication.Encrypt(ticket); HttpCookie FormsCookie = new HttpCookie(FormsAuthentication.FormsCookieName,formsCookieStr); HttpContext.Response.Cookies.Add(FormsCookie);
我希望有效期是一个滑动过期 – 每次客户端发送一个请求,那么到期应该重置为30分钟.但是,我只在用户首次登录时创建机票.ASP.NET会自动保持滑动到期的时间,还是需要手动执行某些操作来实现滑动到期?
解决方法
这是在web.config的表单部分中配置的.滑动过期的工作方式是在每个请求上,ASP.NET引擎通过增加超时来重写身份验证cookie:
<authentication mode="Forms"> <forms loginUrl="~/Account/logon" timeout="2880" slidingExpiration="true" /> </authentication>
不过请注意,启用滑动过期是在ASP.NET Security Practices被认为是坏习惯的事情之一.
原文地址:https://www.jb51.cc/aspnet/249578.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。