首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >升级到MVC4.5/ ASP.NET 4表单身份验证失败

升级到MVC4.5/ ASP.NET 4表单身份验证失败
EN

Stack Overflow用户
提问于 2012-08-19 04:03:45
回答 3查看 22.7K关注 0票数 15

我刚刚下载了VS2012以及MVC4.5和MVC4.0,并用一个示例应用程序进行了测试,发现与ASP.NET 4.0 /MVC3完美兼容的表单身份验证似乎不再适用于最新版本。

当我调用操作控制器中的登录函数时,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);
}

我已经在我的VS2010源代码中用等效的代码替换了这段代码,同样也失败了(使用现已弃用的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>
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12021863

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档