微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Asp.Net Identity – 在运行时设置CookieDomain

如果我想从Request.Url或从我的数据库中存储的某些设置中提取此值,如何在运行时在CookieAuthenticationoptions中设置CookieDOmain?

我想支持子域,但也支持多租户,每个租户都有不同的域.

在配置此时,我无法访问其中任何一个.

保罗

解决方法

您可以指定自己的cookie提供者:
CookieAuthProvider myProvider = new CookieAuthProvider();
app.UseCookieAuthentication(new CookieAuthenticationoptions
{
   AuthenticationType = DefaultAuthenticationTypes.ApplicationCookie,LoginPath = new PathString("/Account/Login"),Provider = myProvider
});

要么实现自己的,要么只是继承现有的提供者:

public class CookieAuthProvider : CookieAuthenticationProvider
{
    public override void ResponseSignIn(CookieResponseSignInContext context)
    {
      //Alter you cookie options
      //context.CookieOptions.Domain  =  "www...";      
      base.ResponseSignIn(context);
    }
 }

并实现ResponseSignIn,当端点在将信息转换为cookie之前提供了登录信息时,会调用它.通过实施该方法,可以改变进入票证的权利要求和额外信息.

您将传递CookieResponseSignInContext,它会公开可在ResponseSignIn调用期间替换或更改的CookieOptions属性.

Katana项目的代码参考:

> ICookieAuthenticationProvider
> CookieResponseSignInContext
> CookieAuthenticationHandler

原文地址:https://www.jb51.cc/aspnet/247687.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐