如何在ASP.NET Core的子域之间共享会话? [英] How can I share session among subdomains in ASP.NET Core?

查看:68
本文介绍了如何在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.

谢谢:)

这篇关于如何在ASP.NET Core的子域之间共享会话?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆