【问题标题】:ASP.Net Core Cookie Authentication is not persistantASP.Net Core Cookie 身份验证不是持久的
【发布时间】:2021-04-22 23:24:30
【问题描述】:

我开始使用 ASP.Net Core 2.2 开发网站。 我正在通过自定义 cookie 身份验证(不是身份)实现登录/注销。

请查看或克隆the repo:

git clone https://github.com/mrmowji/aspcore-custom-cookie-authentication.git .

...或者阅读下面的代码sn-ps。

这是Startup.cs中的代码:

public void ConfigureServices(IServiceCollection services) {
  ...

  services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme)
    .AddCookie(options => {
      options.LoginPath = new PathString("/login");
      options.ExpireTimeSpan = TimeSpan.FromDays(30);
      options.Cookie.Expiration = TimeSpan.FromDays(30);
      options.SlidingExpiration = true;
    });

  ...

public void Configure(IApplicationBuilder app, IHostingEnvironment env) {
  ...

  app.UseHttpsRedirection();
  app.UseStaticFiles();
  app.UseCookiePolicy();

  app.UseAuthentication();

  app.UseMvc(routes =>
  {
    ...

这是Login操作的代码:

public async Task<IActionResult> Login(LoginViewModel userToLogin) {
  var username = "username"; // just to test
  var password = "password"; // just to test
  if (userToLogin.UserName == username && userToLogin.Password == password) {
    var claims = new List<Claim> {
      new Claim(ClaimTypes.Name, "admin"),
      new Claim(ClaimTypes.Role, "Administrator"),
    };

  var claimsIdentity = new ClaimsIdentity(
    claims, CookieAuthenticationDefaults.AuthenticationScheme);

  var authProperties = new AuthenticationProperties {
    AllowRefresh = true,
    ExpiresUtc = DateTimeOffset.UtcNow.AddDays(10),
    IsPersistent = true,
  };

  await HttpContext.SignInAsync(
    CookieAuthenticationDefaults.AuthenticationScheme,
    new ClaimsPrincipal(claimsIdentity),
    authProperties);

    ...

Cookie 已按预期设置。我有一个.AspNetCore.Cookies cookie,有效期为 10 天后。但大约 30 分钟后,用户退出。即使关闭浏览器,如何强制认证用户保持登录状态?

【问题讨论】:

  • @LeonardoSeccia 我没有检查。他/她必须这样做吗?
  • 您可能将IdleTimeout 设置为 30 分钟...无论哪种方式。你也可以分享你的ValidatePrincipal 方法吗(如果你已经覆盖了它)?
  • @LeonardoSeccia 我没有。我在论坛中没有看到任何关于 ValidatePrincipal 的建议解决方案或 tut 这种类型的身份验证。我应该实施吗?
  • 另一个想法...您的服务器是否永久存储 cookie 解密密钥?如果没有,每当服务器或应用程序池重新启动时,用户将不得不再次登录......
  • 你能把它归结为minimal reproducible example吗?

标签: c# authentication asp.net-core cookie-authentication


【解决方案1】:

感谢@LeonardoSeccia 我可以找到答案。请阅读有关主要问题的 cmets。

我只需要在 ConfigureServices 方法中添加 data protection 服务并提供一种方法来存储/持久化密钥(用于加密/解密敏感数据)某处,否则每当服务器或应用程序池重新启动时,将生成新密钥,并且旧的加密数据(包括身份验证 cookie)不会以它们必须的方式解密,从而导致身份验证失败。如果您要部署到像我这样的共享主机,这是必要的。

如果您以前使用过 .Net Framework 中的 ASP.Net,则此数据保护概念在某种程度上等同于 MachineKey

我决定use a file to store the keys。 这是Startup.cs的最终更改:

public Startup(IConfiguration configuration, IHostingEnvironment environment) {
  Configuration = configuration;
  hostingEnvironment = environment;
}

private IHostingEnvironment hostingEnvironment;

public IConfiguration Configuration { get; }

// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services) {
  // create a directory for keys if it doesn't exist
  // it'll be created in the root, beside the wwwroot directory
  var keysDirectoryName = "Keys";
  var keysDirectoryPath = Path.Combine(hostingEnvironment.ContentRootPath, keysDirectoryName);
  if (!Directory.Exists(keysDirectoryPath)) {
    Directory.CreateDirectory(keysDirectoryPath);
  }
  services.AddDataProtection()
    .PersistKeysToFileSystem(new DirectoryInfo(keysDirectoryPath))
    .SetApplicationName("CustomCookieAuthentication");

  services.Configure<CookiePolicyOptions>(options =>
  {
  ...

【讨论】:

  • 我刚遇到同样的问题,有帮助,谢谢。
  • 回购不可用
  • @Erdogan 我一定是误删了它。对不起。
  • 没问题,效果很好:) 谢谢
猜你喜欢
  • 2018-02-24
  • 1970-01-01
  • 2017-10-26
  • 1970-01-01
  • 2018-05-13
  • 2011-06-11
  • 2017-03-30
  • 2012-08-01
  • 1970-01-01
相关资源
最近更新 更多