在我的 AuthenticateRequest 事件处理程序中,我设置了 Thread 的主体。这是我的 IHttpModule 的一部分:
public void Init(HttpApplication context)
{
context.AuthenticateRequest += AuthenticateRequest;
}
private void AuthenticateRequest(object sender, EventArgs e)
{
var principal = CreatePrincipal();
HttpContext.Current.User = principal;
}
但是我有一个程序集,它不应该访问 System.Web,所以我不能使用 HttpContext.Current.User,但我需要访问当前主体。我的第一个想法是将我的方法更改为:
System.Threading.Thread.CurrentPrincipal = HttpContext.Current.User = principal;
并在需要时使用 Thread.CurrentPrincipal。
但据我记得,将请求特定的东西存储在 Thread Local Storage 中是不安全的,因为多个线程可以处理相同的请求,所以我猜它与Thread.CurrentPrincipal相同。或不?