加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

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

发布时间:2020-12-16 04:15:10 所属栏目:asp.Net 来源:网络整理
导读:如果我想从Request.Url或从我的数据库中存储的某些设置中提取此值,如何在运行时在CookieAuthenticationOptions中设置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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读