• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

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

    來源:懂視網 責編:小采 時間:2020-11-27 22:36:45
    文檔

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

    .net core 1.0 實現單點登錄負載多服務器:前言 .net core 出來有一時間了,這段時間也一直在做技術準備,目前想做一個單點登錄(SSO)系統,在這之前用.net時我用習慣了machineKey ,也順手在.net core 中嘗試了一上,結果發現不好使了,也不起作用,于是開始了網上學習。 實現方法 功夫不負有心
    推薦度:
    導讀.net core 1.0 實現單點登錄負載多服務器:前言 .net core 出來有一時間了,這段時間也一直在做技術準備,目前想做一個單點登錄(SSO)系統,在這之前用.net時我用習慣了machineKey ,也順手在.net core 中嘗試了一上,結果發現不好使了,也不起作用,于是開始了網上學習。 實現方法 功夫不負有心

    前言

      .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 實現單點登錄負載多服務器的全部敘述,希望對大家有所幫助!

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

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

    .net core 1.0 實現單點登錄負載多服務器:前言 .net core 出來有一時間了,這段時間也一直在做技術準備,目前想做一個單點登錄(SSO)系統,在這之前用.net時我用習慣了machineKey ,也順手在.net core 中嘗試了一上,結果發現不好使了,也不起作用,于是開始了網上學習。 實現方法 功夫不負有心
    推薦度:
    標簽: 1.0 net 單點
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 国产精品美女久久久| 在线电影国产精品| 亚洲精品成人av在线| 一区二区日韩国产精品| 国产精品自在线拍国产电影| 精品福利资源在线| 国产欧美精品AAAAAA片| 亚洲级αV无码毛片久久精品| 精品91自产拍在线观看| 四虎永久在线精品884aa下载| 国产精品无码成人午夜电影| 亚洲国产精品一区二区成人片国内| 精品无码国产自产拍在线观看蜜| 91精品婷婷国产综合久久| 国产精品www| 久久精品黄AA片一区二区三区| 亚洲国产成人乱码精品女人久久久不卡| 国产综合精品久久亚洲| 99riav国产精品| 久久免费国产精品一区二区| 国产精品扒开腿做爽爽爽视频| 无码精品国产VA在线观看| 婷婷久久精品国产| 人妻一区二区三区无码精品一区| 精品久久久久久无码中文字幕| 国产午夜精品理论片久久| 国产精品自在线拍国产电影| 国产精品内射婷婷一级二| 国产高清精品一区| 成人午夜精品久久久久久久小说 | 国产在AJ精品| 国产精品亚洲专区无码WEB| 国产精品美女久久久久AV福利| 99免费精品国产| 国产精品午夜无码AV天美传媒 | 国产A∨国片精品一区二区| 亚洲午夜精品久久久久久人妖| 久久精品国产69国产精品亚洲| 午夜精品美女写真福利| 成人精品一区二区三区免费看 | 无码人妻精品一区二区三区在线|