Kat*_*tya 6 asp.net forms-authentication httpcontext
在大约100多个用户使用表单身份验证登录到站点的环境中,调用HttpContext.Current.User.Identity.Name将返回正确登录的用户.
但是,有10%的时间返回了错误的用户全名信息.我的测试机器上从未出现过这样的问题,它只发生在生产中.我无法在我的测试机器上为许多用户重新创建相同的环境.
这个应用程序的逻辑:
1)用户输入用户名并通过,通过SQL DB调用查询信息,如果匹配,则通过FormsAuthentication.RedirectFromLoginPage(username,false)验证用户
FormsAuthentication.SetAuthCookie(user.SYS_Users_ID.ToString(), false);
if (Request["ReturnURL"] == null)
FormsAuthentication.RedirectFromLoginPage(user.SYS_Users_ID.ToString(), false);
else
Response.Redirect("/" + SysConfig.ApplicationName + appConfig.DefaultPages.DefaultPage);
Run Code Online (Sandbox Code Playgroud)
2)重定向后,我将用户全名放入隐藏字段
if (!IsPostBack)
userFullName.Value = Helper.GetCurrentUserFullName();
...
public static string GetCurrentUserFullName()
{
string _userFullName = string.Empty;
try
{
_userFullName = new AgrotMasofim.DAL.Users.Users().GetUserFullName(GetCurrentUserID());
}
catch (Exception ex)
{
Logs.WriteToFileLog(string.Empty,ex);
}
return _userFullName;
}
public static Decimal GetCurrentUserID()
{
Decimal _userID = 0;
if (HttpContext.Current.User != null)
{
try
{
_userID = Convert.ToDecimal(HttpContext.Current.User.Identity.Name);
}
catch (Exception ex)
{
Logs.WriteToFileLog(string.Empty, ex);
}
}
return _userID;
}
Run Code Online (Sandbox Code Playgroud)
3)在用户访问的所有页面上,他/她的信息显示在母版页上的标签内
lblUserName.Text = HttpUtility.HtmlDecode("Hello " + userFullName.Value);
Run Code Online (Sandbox Code Playgroud)
这几乎一直都有效.任何想法为什么它可能会不时失败?
没有更多代码,我只能猜测你的问题。由于其他人可能会发现您的问题并遇到类似的问题,因此我猜测您的问题在于错误使用静态类或属性。
您的GetCurrentUserFullName()方法可能依赖于在所有线程之间静态共享的数据访问方法。数据访问类中可能存在竞争条件,有时会导致在检索数据之前搜索的用户 ID 被另一个请求中的 ID 替换。解决方案是(a)在数据访问类的所有关键部分使用锁,或者(b)使用为每个请求(实际上是每个工作单元)实例化一个新数据访问类的解决方案)。后一种设计要求您的数据访问类是轻量级的,但更可取,因为它也更容易测试。
如果您在静态属性或其他在线程之间共享的静态类中缓存值,也可能会遇到类似的竞争条件,其中这些值被缓存和使用。类似的解决方案也适用 - 使用锁定或使用每线程实例而不是静态实例。
| 归档时间: |
|
| 查看次数: |
2684 次 |
| 最近记录: |