Я пытался проверить, является ли пользователь в роли Application_BeginRequest и Application_AuthenticateRequest с этим кодом, и он не будет работать. В BeginRequest код никогда не проверяется, а для проверки подлинности он обрабатывается некоторыми запросами, а профилировщик не отображается.
Проверка только по запросу. Отлично работает.
if(Request.IsAuthenticated)
{
if(User.IsInRole("Admin");
MiniProfiler.Start();
}
Любая идея или почему это не работает или лучший способ сделать это?
[Обновление] Я принял awnser, но отменил его, так как не совсем понял, как он работает
Я сделал следующее, но профилировщик сначала не отображается.
После нескольких попыток он начал появляться, даже когда я пытался войти на сайт в режиме инкогнито, поэтому cookie не было.
protected void Application_PostAuthorizeRequest(Object sender, EventArgs e)
{
if (User.IsInRole("Admin"))
{
HttpCookie cookie = HttpContext.Current.Request.Cookies.Get("RoleProfiler");
if (cookie == null)
{
cookie = new HttpCookie("RoleProfiler");
cookie.Value = "yes";
cookie.Expires = DateTime.Now.AddDays(1d);
Response.Cookies.Add(cookie);
}
}
}
И я проверяю с
protected void Application_BeginRequest(Object sender, EventArgs e)
{
HttpCookie cookie = HttpContext.Current.Request.Cookies.Get("RoleProfiler");
if ((cookie != null) && (cookie.Value == "yes") )
{
MvcMiniProfiler.MiniProfiler.Start();
}
}
И заканчивается в конце запроса.
protected void Application_EndRequest()
{
MvcMiniProfiler.MiniProfiler.Stop();
}
[Update2] Заключительный вопрос, игнорируйте это, я принадлежал outputcache.