asp.net mvc Добавление к атрибуту AUTHORIZE - PullRequest
12 голосов
/ 16 февраля 2009

Как создать пользовательский атрибут для расширения существующего атрибута Authorize в MVC?

Ответы [ 4 ]

17 голосов
/ 16 февраля 2009

Получите ваш класс из AuthorizeAttribute. Переопределите метод OnAuthorization. Добавьте и настройте CacheValidationHandler.

public void CacheValidationHandler( HttpContext context,
                                    object data,
                                    ref HttpValidationStatus validationStatus )
{
    validationStatus = OnCacheAuthorization( new HttpContextWrapper( context ) );
}


public override void OnAuthorization( AuthorizationContext filterContext )
{
    if (filterContext == null)
    {
        throw new ArgumentNullException( "filterContext" );
    }

    if (AuthorizeCore( filterContext.HttpContext ))
    {
       ... your custom code ...
       SetCachePolicy( filterContext );
    }
    else if (!filterContext.HttpContext.User.Identity.IsAuthenticated)
    {
        // auth failed, redirect to login page
        filterContext.Result = new HttpUnauthorizedResult();
    }
    else
    {
       ... handle a different case than not authenticated
    }
}


protected void SetCachePolicy( AuthorizationContext filterContext )
 {
     // ** IMPORTANT **
     // Since we're performing authorization at the action level, the authorization code runs
     // after the output caching module. In the worst case this could allow an authorized user
     // to cause the page to be cached, then an unauthorized user would later be served the
     // cached page. We work around this by telling proxies not to cache the sensitive page,
     // then we hook our custom authorization code into the caching mechanism so that we have
     // the final say on whether a page should be served from the cache.
     HttpCachePolicyBase cachePolicy = filterContext.HttpContext.Response.Cache;
     cachePolicy.SetProxyMaxAge( new TimeSpan( 0 ) );
     cachePolicy.AddValidationCallback( CacheValidationHandler, null /* data */);
 }
10 голосов
/ 16 февраля 2009

Вам не нужно расширять этот атрибут, достаточно web.config. Пожалуйста, прочитайте о Элемент формы для аутентификации . Обратите внимание на defaultUrl. Это то, что вам нужно.

<system.web>
  <authentication mode="Forms">
    <forms defaultUrl="YourUrlGoesHere"/>
  </authentication>
</system.web>
3 голосов
/ 16 февраля 2009
public class CoolAuthorizeAttribute :  AuthorizeAttribute
{
}
0 голосов
/ 05 июля 2012

Я предлагаю, если вы просто хотите расширить текущий AuthorizeAttribute и добавить к нему свою собственную авторизацию, вместо переопределения OnAuthorization, просто переопределите AuthorizeCore и добавьте к нему условие MyCustomAuthorizationHolds.

public class CustomAuthorizeAttribute : AuthorizeAttribute
{
    // This method must be thread-safe since it is called by the thread-safe OnCacheAuthorization() method.
    protected override bool AuthorizeCore(HttpContextBase httpContext)
    {
        if (base.AuthorizeCore(httpContext) && MyCustomAuthorizationHolds)
            return true;

        return false;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...