问题描述
我有一个网站,其子域名如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的子域之间共享会话?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!