我刚刚下载了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>
发布于 2012-08-31 00:46:11
这里的问题是,默认的mvc4 internet模板使用SimpleMembership来管理成员/角色信息。模板中的代码假设了这一点,并且只能与简单成员一起工作。安装通用提供程序时,帐户控制器代码会崩溃,因为它无法理解通用提供程序。请看这篇文章,它进一步解释了这个场景http://weblogs.asp.net/jgalloway/archive/2012/08/29/simplemembership-membership-providers-universal-providers-and-the-new-asp-net-4-5-web-forms-and-asp-net-mvc-4-templates.aspx
发布于 2012-08-22 02:43:26
如果需要在使用旧版本.NET框架的应用程序之间共享窗体身份验证票证,则必须将.NET 4.5应用程序显式配置为使用较早的计算机兼容模式,否则它们将无法加密/解密窗体身份验证票证。
在.net 4.5应用程序的web.config中,设置兼容性模式属性:
<system.web>
<machineKey compatibilityMode="Framework20SP2" />
</system.web>
这将允许您的.NET 4.5应用程序使用由早期.NET版本生成的表单身份验证票证。
注意:如果您的任何服务器没有安装.NET Framework2.0 SP2,则需要将兼容模式设置为"Framework20SP1“。
发布于 2012-08-20 07:06:02
对我来说,我遇到了一个问题,因为您需要(从http://www.asp.net/whitepapers/mvc4-release-notes)对web.config设置进行一些更改
<appSettings>
<add key="webpages:Version" value="2.0.0.0" />
<add key="PreserveLoginUrl" value="true" />
</appSettings>
当我遇到登录问题时,修复这些设置(看起来不像是你添加的)可以帮助我解决问题。
https://stackoverflow.com/questions/12021863
复制相似问题