我使用的是ASP.NET身份,它可以通过常规登录和外部登录在本地完美运行。出于某种原因,当我发布我的项目并在远程服务器上运行它时,我的授权会话大约有1分钟。 1分钟后,我被重定向到我的登录页面。 (没有错误信息)
我的启动验证配置:
public partial class Startup
{
public void ConfigureAuth(IAppBuilder app)
{
app.CreatePerOwinContext(ApplicationDbContext.Create);
app.CreatePerOwinContext<ApplicationUserManager>(ApplicationUserManager.Create);
app.CreatePerOwinContext<ApplicationSignInManager>(ApplicationSignInManager.Create);
app.UseCookieAuthentication(new CookieAuthenticationOptions
{
AuthenticationType = DefaultAuthenticationTypes.ApplicationCookie,
LoginPath = new PathString("/Account/Login"),
ExpireTimeSpan = TimeSpan.FromDays(2),
Provider = new CookieAuthenticationProvider
{
OnValidateIdentity = SecurityStampValidator.OnValidateIdentity<ApplicationUserManager, VisU>(
validateInterval: TimeSpan.FromMinutes(30),
regenerateIdentity: (manager, user) => user.GenerateUserIdentityAsync(manager))
}
});
var googleOptions = new GoogleOAuth2AuthenticationOptions()
{
ClientId = "***",
ClientSecret = "***",
SignInAsAuthenticationType = DefaultAuthenticationTypes.ExternalCookie,
Provider = new GoogleOAuth2AuthenticationProvider()
{
OnAuthenticated = (context) =>
{
context.Identity.AddClaim(new Claim("urn:google:name", context.Identity.FindFirstValue(ClaimTypes.Name)));
context.Identity.AddClaim(new Claim("urn:google:email", context.Identity.FindFirstValue(ClaimTypes.Email)));
context.Identity.AddClaim(new Claim("urn:google:accesstoken", context.AccessToken, ClaimValueTypes.String, "Google"));
return Task.FromResult(0);
}
}
};
app.UseGoogleAuthentication(googleOptions);
}
我的帐户管理员:
[AllowAnonymous]
public ActionResult Login(string returnUrl)
{
ViewBag.ReturnUrl = returnUrl;
return View();
}
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task<string> Login()
{
var result = await SignInManager.PasswordSignInAsync(Request.Form["emailLogin"], Request.Form["passwordLogin"], true, shouldLockout: true);
switch (result)
{
case SignInStatus.Success:
return ViewBag.ReturnUrl ?? "https://localhost:44300/Account";
case SignInStatus.LockedOut:
return Resources.Multilang.ERRORLockedOut;
case SignInStatus.Failure:
//Mail or password are incorrect
return Resources.Multilang.ERRORInvalidLogin;
default:
return Resources.Multilang.ERRORInvalidLogin;
}
}
这种行为可能是什么原因?
(&#34; https://localhost:44300/&#34;在发布时更改为我的域名。)
答案 0 :(得分:1)
此问题的最常见原因之一是未在web.config中设置MachineKey
元素。 MachineKey
用于加密和解密诸如授权cookie之类的内容。如果未设置MachineKey
元素,IIS将为您组成MachineKey
。
如果这是一个问题,如果您将应用程序发布到第三方Web托管,例如Azure或GoDaddy。这些提供程序通常在多个Web服务器上具有Web应用程序。由于Web服务器将自己构建MachineKey
(如果未设置),因此托管应用程序的每个Web服务器都将拥有自己的MachineKey
。最终结果是Web服务器A发布并加密授权cookie。如果下一个请求进入Web服务器B,它将无法解密和读取cookie,因此它假定您没有登录。
在web.config中设置MachineKey
可确保托管应用程序的每台Web服务器都可以加密和解密授权cookie而不会出现问题。