Не видеть роли на Принципале в приложении ASP.NET MVC 2 - PullRequest
0 голосов
/ 11 августа 2010

Я пишу приложение ASP.NET MVC 2 и не хочу использовать членство в ASP.NET. Я хочу использовать атрибут Authorize на контроллерах. То, что я сделал до сих пор, это ...

Web.config

<roleManager enabled="true" />

<authentication mode="Forms">
  <forms loginUrl="~/Authentication/Login" timeout="2880"/>
</authentication>
<authorization>
  <allow users="*" /> /* This is for testing */
</authorization>

В моем Global.asax

 protected void Application_AuthenticateRequest(Object sender, EventArgs e)
    {
        var cookie = Context.Request.Cookies[FormsAuthentication.FormsCookieName];

        if (cookie == null) return;
        var decryptedCookie = FormsAuthentication.Decrypt(cookie.Value);            
        var roles = decryptedCookie.UserData.Split('|');

        var tcmIdentity = new TcmIdentity(decryptedCookie.Name);
        var tcmPrincipal = new GenericPrincipal(tcmIdentity, roles);

        Context.User = tcmPrincipal;
    }

Я использую пользовательский IIdentity, чтобы я мог добавить некоторые пользовательские свойства в будущем. Чтобы проверить это в моем действии контроллера, я сделал это ...

var testPrincipal = User;

Я вижу пользовательское удостоверение со всей пользовательской информацией, но в основном объекте нет ролей. Любая помощь с тем, что я пропустил, была бы великолепна. Спасибо.

Ответы [ 2 ]

1 голос
/ 11 августа 2010

UPDATE:

В конце концов я получил эту работу, изменив

protected void Application_AuthenticateRequest(Object sender, EventArgs e)
{
    var cookie = Context.Request.Cookies[FormsAuthentication.FormsCookieName];

    if (cookie == null) return;
    var decryptedCookie = FormsAuthentication.Decrypt(cookie.Value);            
    var roles = decryptedCookie.UserData.Split('|');

    var tcmIdentity = new TcmIdentity(decryptedCookie.Name);
    var tcmPrincipal = new GenericPrincipal(tcmIdentity, roles);

    Context.User = tcmPrincipal;
}

до

protected void Application_AuthenticateRequest(Object sender, EventArgs e)
{
    var cookie = Context.Request.Cookies[FormsAuthentication.FormsCookieName];

    if (cookie == null) return;
    var decryptedCookie = FormsAuthentication.Decrypt(cookie.Value);            
    var roles = decryptedCookie.UserData.Split('|');

    var tcmIdentity = new TcmIdentity(decryptedCookie.Name);
    var tcmPrincipal = new GenericPrincipal(tcmIdentity, roles);

    Thread.CurrentPrincipal = Context.User = tcmPrincipal;
}
1 голос
/ 11 августа 2010

Полагаю, вам нужен поставщик ролей.Подобно тому, как поставщик членства обрабатывает членство пользователей, создает, удаляет, проверяет, редактирует, чтобы использовать роли, вам нужно использовать RoleProvider ( ASP.NET Реализация поставщика ролей ).

Что также требует включения ролей в web.config, например:

<roleManager enabled="enabled" defaultProvider="AspNetSqlRoleProvider">
  <providers>
    <clear/>
      <add name="AspNetSqlRoleProvider" 
           type="System.Web.Security.SqlRoleProvider"
           connectionStringName="ApplicationServices" 
           applicationName="/" />
      <add name="AspNetWindowsTokenRoleProvider"
           type="System.Web.Security.WindowsTokenRoleProvider"
           applicationName="/" />
  </providers>
</roleManager>

Это может быть полезно: SO asp-net-mvc-role-without-database-and-без поставщика ролей

Как может быть: ASP.NET 2.0, назначение пользовательских ролей без «поставщика ролей»

...