麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > .NET > 正文

.net core 1.0 實現單點登錄負載多服務器

2024-07-10 13:31:05
字體:
來源:轉載
供稿:網友

前言

  .net core 出來有一時間了,這段時間也一直在做技術準備,目前想做一個單點登錄(SSO)系統,在這之前用.net時我用習慣了machineKey ,也順手在.net core 中嘗試了一上,結果發現不好使了,也不起作用,于是開始了網上學習。

實現方法

  功夫不負有心人,網上高人還是多,在github.com上面ISSUES中也有人在討論此問題,于是找到代碼嘗試,結果實現了。

  直接上代碼,我們需要先封裝一個XmlRepository,Key的格式如下:

 <?xml version="1.0" encoding="utf-8"?><key id="cbb8a41a-9ca4-4a79-a1de-d39c4e307d75" version="1"> <creationDate>2016-07-23T10:09:49.1888876Z</creationDate> <activationDate>2016-07-23T10:09:49.1388521Z</activationDate> <expirationDate>2116-10-21T10:09:49.1388521Z</expirationDate> <descriptor deserializerType="Microsoft.AspNetCore.DataProtection.AuthenticatedEncryption.ConfigurationModel.AuthenticatedEncryptorDescriptorDeserializer, Microsoft.AspNetCore.DataProtection, Version=1.1.0.0, Culture=neutral, PublicKeyToken=adb9793829ddae60">  <descriptor>   <encryption algorithm="AES_256_CBC" />   <validation algorithm="HMACSHA256" />   <masterKey p4:requiresEncryption="true" xmlns:p4="http://schemas.asp.net/2015/03/dataProtection">    <!-- Warning: the key below is in an unencrypted form. -->    <value>WYgZNh/3dOKRYJ1OAhVqs56pWPMHei15Uj44DPLWbYUiCpNVEBwqDfYAUq/4jBKYrNoUbaRkGY5o/NZ6a2NTwA==</value>   </masterKey>  </descriptor> </descriptor></key>

XmlRepository代碼:

public class CustomFileXmlRepository : IXmlRepository  {    private readonly string filePath = @"C:/keys/key.xml";    public virtual IReadOnlyCollection<XElement> GetAllElements()    {      return GetAllElementsCore().ToList().AsReadOnly();    }    private IEnumerable<XElement> GetAllElementsCore()    {      yield return XElement.Load(filePath);    }    public virtual void StoreElement(XElement element, string friendlyName)    {      if (element == null)      {        throw new ArgumentNullException(nameof(element));      }      StoreElementCore(element, friendlyName);    }    private void StoreElementCore(XElement element, string filename)    {    }  }

Startup代碼:

 public class Startup  {    public Startup(IHostingEnvironment env)    {      var builder = new ConfigurationBuilder()        .SetBasePath(env.ContentRootPath)        .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)        .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true)        .AddEnvironmentVariables();      Configuration = builder.Build();    }    public IConfigurationRoot Configuration { get; }    // This method gets called by the runtime. Use this method to add services to the container.    public void ConfigureServices(IServiceCollection services)    {      services.AddSingleton<IXmlRepository, CustomFileXmlRepository>();      services.AddDataProtection(configure =>      {        configure.ApplicationDiscriminator = "Htw.Web";      });      // Add framework services.      services.AddMvc();    }    // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.    public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)    {      loggerFactory.AddConsole(Configuration.GetSection("Logging"));      loggerFactory.AddDebug();      if (env.IsDevelopment())      {        app.UseDeveloperExceptionPage();        app.UseBrowserLink();      }      else      {        app.UseExceptionHandler("/Home/Error");      }      app.UseStaticFiles();      app.UseCookieAuthentication(new CookieAuthenticationOptions()      {        AuthenticationScheme = CookieAuthenticationDefaults.AuthenticationScheme,        LoginPath = new PathString("/Account/Unauthorized/"),        AccessDeniedPath = new PathString("/Account/Forbidden/"),        AutomaticAuthenticate = true,        AutomaticChallenge = false,        CookieHttpOnly = true,        CookieName = "MyCookie",        ExpireTimeSpan = TimeSpan.FromHours(2),#if !DEBUG        CookieDomain="h.cn",#endif        DataProtectionProvider = null      });      app.UseMvc(routes =>      {        routes.MapRoute(          name: "default",          template: "{controller=Home}/{action=Index}/{id?}");      });    }  }

登錄代碼:

  public async void Login()    {      if (!HttpContext.User.Identities.Any(identity => identity.IsAuthenticated))      {        var user = new ClaimsPrincipal(new ClaimsIdentity(new[] { new Claim(ClaimTypes.Name, "bob") }, CookieAuthenticationDefaults.AuthenticationScheme));        await HttpContext.Authentication.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, user);        HttpContext.Response.ContentType = "text/plain";        await HttpContext.Response.WriteAsync("Hello First timer");      }      else      {        HttpContext.Response.ContentType = "text/plain";        await HttpContext.Response.WriteAsync("Hello old timer");      }    }

注意

C:/keys/key.xml 這個文件路徑可以更改,還有就是也可用共享目錄或數據庫來實現統一管理

到此可以登錄試一下。

以上所述是小編給大家介紹的.net core 1.0 實現單點登錄負載多服務器的全部敘述,希望對大家有所幫助!


注:相關教程知識閱讀請移步到ASP.NET教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩av在线资源 | 九九午夜视频 | 久久亚洲美女视频 | 操操操日日日干干干 | 黄网站在线免费看 | 亚洲视频精选 | 免费网站看毛片 | 久久免费激情视频 | av电影手机在线看 | 中文字幕在线视频日本 | 国产亚洲精品综合一区91555 | 男男啪羞羞视频网站 | 国产精品美女一区二区 | 在线成人免费观看视频 | 国产亚洲精品yxsp | 亚洲射吧| 香蕉秀| 精品一区二区在线播放 | 毛片免费在线观看 | 中文字幕综合在线观看 | 黄色成人小视频 | 新久草在线视频 | 91在线视频免费观看 | 激情综合视频 | xxxx8| 精品一区二区三区毛片 | 亚洲国产高清视频 | 一本色道久久综合亚洲精品小说 | 久久久一区二区三区四区 | 精品午夜影院 | 热99在线视频 | 日韩欧美精品中文字幕 | 欧美性受xxx黑人xyx性爽 | 热@国产 | 日韩精品中文字幕一区二区 | 九九视频在线观看6 | 羞羞答答影院 | 中文字幕免费在线观看视频 | 国产中文99视频在线观看 | 性高跟鞋xxxxhd4kvideos | 亚洲综合精品 |