如何在MVC3中授权不同的登录URL?

Teo*_*ris 1 asp.net-mvc-3

大家好我有两次登录,但如何使用授权分配这些登录URL?

这是我的webconfig:

 <location path="Home">
    <system.web>
      <authorization>
        <deny users="?"/>
      </authorization>
    </system.web>  
  </location>


 <authentication mode="Forms">
      <forms loginUrl="~/Home/Login" timeout="2880" />
    </authentication>
Run Code Online (Sandbox Code Playgroud)

那么如何创建第二个loginurl?

Dar*_*rov 6

您无法在Forms身份验证中拥有2个登录网址.如果您需要实现此功能,您可以编写自定义[Authorize]属性,然后覆盖HandleUnauthorizedRequest方法,您可以在其中重定向到相应的登录URL.

例如:

public class MyAuthorizeAttribute : AuthorizeAttribute
{
    private readonly string _controller;
    private readonly string _action;
    public MyAuthorizeAttribute(): this("account", "logon")
    {
    }

    public MyAuthorizeAttribute(string controller, string action)
    {
        _controller = controller;
        _action = action;
    }

    protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)
    {
        var values = new RouteValueDictionary(new
        {
            controller = _controller,
            action = _action,
            returnurl = filterContext.HttpContext.Request.Url.PathAndQuery
        });
        filterContext.Result = new RedirectToRouteResult(values);
    }
}
Run Code Online (Sandbox Code Playgroud)

然后:

public class SomeController
{
    [MyAuthorize]
    public ActionResult Foo()
    {
        return View();
    }

    [MyAuthorize("account", "someotherlogonaction")]
    public ActionResult Bar()
    {
        return View();
    }
}
Run Code Online (Sandbox Code Playgroud)