При обновлении до ASP.NET 4.5 / MVC 4 формы проверка подлинности завершается неудачно

Я только что загрузил VS 2012 вместе с ASP.NET 4.5 и MVC 4.0, пинал шины с помощью примера приложения и обнаружил, что аутентификация форм, которая отлично работает с ASP.NET 4.0 / MVC 3, больше не работает с последний релиз.

Когда я вызываю функцию Login в контроллере действий, происходит сбой вызова WebSecurity.Login:

public ActionResult Login(LoginModel model, string returnUrl)
{
    if (ModelState.IsValid && WebSecurity.Login(model.UserName, model.Password, persistCookie: model.RememberMe))
    {
        return RedirectToLocal(returnUrl);
    }

    // If we got this far, something failed, redisplay form
    ModelState.AddModelError("", "The user name or password provided is incorrect.");
    return View(model);
}

Я заменил этот код на аналогичный в моем источнике VS 2010, и это также не помогло (с помощью устаревшей функции FormsAuthentication.Authenticate).

Мой вопрос: кто-нибудь портировал приложение MVC3 на MVC4 и нашел решение этой проблемы? Я использую IIS Express, так что я думаю, что это может как-то вызывать некоторые проблемы, но если у вас есть какие-либо идеи, я буду признателен за это.

Я скопировал свою конфигурацию из моего рабочего приложения asp.net 4 / MVC3 следующим образом, но не повезло (здесь соответствующие части):

  <connectionStrings>
    <add name="DefaultConnection" connectionString="Data Source=tcp:sql2k1201.dbprovider.net;Initial Catalog=SQL2012_db;User ID=SQL2012_db_user;Password=dbpassword;" providerName="System.Data.SqlClient" />
  </connectionStrings>

  <system.web>
    <compilation debug="true" targetFramework="4.5" />
    <httpRuntime targetFramework="4.5" />

    <authentication mode="Forms">
      <forms loginUrl="~/Account/Login" timeout="2880"/>
    </authentication>

    <membership>
      <providers>
        <clear/>
        <add name="AspNetSqlMembershipProvider" type="System.Web.Security.SqlMembershipProvider" connectionStringName="DefaultConnection"
           enablePasswordRetrieval="false" enablePasswordReset="true" requiresQuestionAndAnswer="false" requiresUniqueEmail="false"
           maxInvalidPasswordAttempts="5" minRequiredPasswordLength="6" minRequiredNonalphanumericCharacters="0" passwordAttemptWindow="10"
           applicationName="/" />
      </providers>
    </membership>

    <profile>
      <providers>
        <clear/>
        <add name="AspNetSqlProfileProvider" type="System.Web.Profile.SqlProfileProvider" connectionStringName="DefaultConnection" applicationName="/" />
      </providers>
    </profile>

    <roleManager enabled="true">
      <providers>
        <clear/>
        <add name="AspNetSqlRoleProvider" type="System.Web.Security.SqlRoleProvider" connectionStringName="DefaultConnection" applicationName="/" />
      </providers>
    </roleManager>

Ответы на вопрос(3)

Ваш ответ на вопрос