如何在ASP.NET Core的子域之间共享会话?

问题描述:

我有一个网站,其子域名如ali.sarahah.com,但如果用户从 www.sarahah.com 登录,则转到 ali.sarahah.com 会话未保存.搜索后,我在 Startup.cs 中添加了以下内容:

I have a website which has subdomains such as ali.sarahah.com but if a user logs in from www.sarahah.com then goes to ali.sarahah.com the session is not saved. After searching I added the following in Startup.cs:

app.UseCookieAuthentication(new CookieAuthenticationOptions
{
    CookieDomain = ".sarahah.com"
});

我发现.AspNetCore.Identity.Application cookie域仍显示子域而不是域,并且会话问题仍然存在.

I found out that .AspNetCore.Identity.Application cookie domain is still showing the subdomain and not the the domain and that session problem is still there.

我做错什么了吗?

我能够通过将其添加到Startup.cs中的ConfigureServices方法中来解决它:

I was able to solve it by adding this to ConfigureServices method in Startup.cs:

        services.AddIdentity<ApplicationUser, IdentityRole>(options =>
        {
            options.Cookies.ApplicationCookie.CookieDomain = ".yourdomain.com";
            options.Cookies.ApplicationCookie.CookieSecure = Microsoft.AspNetCore.Http.CookieSecurePolicy.None;
        })

CookieSecure部分是因为我的网站在不同页面的http和https之间移动.

The CookieSecure part is because my site moves between http and https in different pages.

谢谢:)